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1. Programarea Orientatà Obiect (POO) 
1.1. Evolutia tehnicilor de programare 


e Programarea nestructuratá (un program simplu, ce utilizeazá numai variabile globale); 
complicatiile apar cand prelucrarea devine mai ampla, iar datele se multiplicá si se diversifica. 


e Programarea proceduralá (program principal deservit de subprograme cu parametri 
formali, variabile locale si apeluri cu parametri efectivi); se obtin avantaje privind depanarea 
si reutilizarea codului si se aplicá noi tehnici privind transferul parametrilor si vizibilitatea 
variabilelor; complicațiile apar atunci cand la program sunt asignati doi sau mai multi 
programatori care nu pot lucra simultan pe un acelasi fisier ce contine codul sursá. 


e Programarea modulară (gruparea subprogramelor cu program principal 
date 


functionalitáti similare in module, implementate si depanate 
separat); se obtin avantaje privind independenta si 
incapsularea (prin separarea zonei de implementare, 
pästränd vizibilitatea numai asupra zonei de interfatá a 

; modul_ 2 

(date+date2) 

* subprog 1 

* subprog 2 


modul 1 
(date+date 1) 
* subprog 1 
* subprog 2 
* subprog 3 


modulului) si se aplicá tehnici de asociere a procedurilor cu 
datele pe care le manevreazá, stabilind si diferite reguli de 
acces la date si la subprograme. 

Se observa cá modulele sunt "centrate" pe proceduri, 
acestea gestionänd si setul de date pe care le prelucreazä 
(date+date1 din figura). Daca, de exemplu, dorim să avem mai multe seturi diferite de date, 
toate înzestrate comportamental cu procedurile din modulul module,, această arhitectură de 
aplicaţie nu este avantajoasă. 


e Programarea orientată obiect (programe cu noi tipuri ce 
integrează atât datele, cât şi metodele asociate creării, 
prelucrării şi distrugerii acestor date); se obţin avantaje prin 
abstractizarea programării (programul nu mai este o succesiune 
de prelucrări, ci un ansamblu de obiecte care prind viata, au 
diverse proprietăți, sunt capabile de acţiuni specifice şi care 
interacționează în cadrul programului); intervin tehnici noi privind 
instantierea, derivarea si polimorfismul tipurilor obiectuale. 


obiect1 obiect4 


1.2. Tipuri de date obiectuale. Incapsulare 


Un tip de date abstract (ADT) este o entitate caracterizatä printr-o structurä de date si 
un ansamblu de operații aplicabile acestor date. Considerând, în rezolvarea unei probleme 
de gestiune a accesului utilizatorilor la un anumit site, tipul abstract USER, vom obseva că 
sunt multe date ce caracterizează un utilizator Internet. Totuşi se va tine cont doar de datele 
semnificative pentru problema dată. Astfel, "culoarea ochilor” este irelevantă în acest caz, în 
timp ce "data naşterii” poate fi importantă. În aceeaşi idee, operaţii specifice ca "se 
înregistrează”, 'comandá on-line” pot fi relevante, în timp ce operaţia "manánca” nu este, în 
cazul nostru. Evident, nici nu se pun în discuţie date sau operaţii nespecifice ("numărul de 
laturi” sau acţiunea "zboara”). 


Operatiile care sunt accesibile din afara entității formează interfața acesteia. Astfel, 
operaţii interne cum ar fi conversia datei de naştere la un număr standard calculat de la 
01.01.1900 nu fac parte din interfaţa tipului de date abstract, în timp ce operaţia "plasează o 
comandă on-line" face parte, deoarece permite interacțiunea cu alte obiecte (SITE, STOC etc.) 

O instanță a unui tip de date abstract este o "concretizare" a tipului respectiv, formată 
din valori efective ale datelor. 

Un tip de date obiectual este un tip de date care implementează un tip de date abstract. 
Vom numi operaţiile implementate în cadrul tipului de date abstract metode. Spunem că 
datele şi metodele sunt membrii unui tip de date obiectual. Folosirea unui astfel de tip 
presupune: existenţa definiţiei acestuia, apelul metodelor şi accesul la date. 
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Un exemplu de-acum clasic de tip de date abstract este STIVA. Ea poate avea ca date: 
numerele naturale din stivá, capacitatea stivei, várful etc. lar operatiile specifice pot fi: 
introducerea in stiva (push) si extragerea din stivá (pop). La implementarea tipului STIVA, 
vom defini o structura de date care sa retina valorile memorate in stivá si campuri de date 
simple pentru: capacitate, numár de elemente etc. Vom mai defini metode (subprograme) 
capabile sà creeze o stivá vidá, care sà introducá o valoare in stiva, sá extragä valoarea din 
värful stivei, sá testeze dacá stiva este vidá sau dacä stiva este plinä etc. 

Crearea unei instante noi a unui tip obiectual, presupune operatii specifice de 
"construire" a noului obiect, metoda corespunzátoare purtänd numele de constructor. Analog, 
la desfiintarea unei instante si eliberarea spatiului de memorie aferent datelor sale, se aplicá 
o metodá specificä numitä destructor’. 

O aplicatie ce utilizeazä tipul obiectual STIVA, va putea construi douä sau mai multe 
stive (de cárti de joc, de exemplu), le va umple cu valori distincte, va muta valori dintr-o stiva 
in alta după o anumită regula desfiintánd orice stivă golita, până ce rămâne o singură stivă. 
De observat că toate aceste prelucrări recurg la datele, constructorul, destructorul şi la 
metodele din interfaţa tipului STIVA descris mai sus. 

Principalul tip obiectual întâlnit în majoritatea mediilor de dezvoltare (Viisual Basic, 
Delphi, C++, Java, C#) poartă numele de clasă (class). Există şi alte tipuri obiectuale (struct, 
object). O instanţă a unui tip obiectual poartă numele de obiect. 


La implementare, datele şi metodele asociate trebuie să fie complet şi corect definite, 
astfel încât utilizatorul să nu fie nevoit să ţină cont de detalii ale acestei implementări. El va 
accesa datele, prin intermediul proprietăţilor şi va efectua operaţiile, prin intermediul 
metodelor puse la dispoziţie de tipul obiectual definit. Spunem că tipurile de date obiectuale 
respectă principiul încapsulării. Astfel, programatorul ce utilizează un tip obiectual CONT (în 
bancă) nu trebuie să poarte grija modului cum sunt reprezentate în memorie datele 
referitoare la un cont sau a algoritmului prin care se realizează actualizarea soldului conform 
operaţiilor de depunere, extragere şi aplicare a dobânzilor. EL va utiliza unul sau mai multe 
conturi (instanțe ale tipului CONT), accesând proprietăţile şi metodele din interfaţă, 
realizatorul tipului obiectual asumându-şi acele griji în momentul definirii tipului CONT. 

Permitánd extensia tipurilor de date abstracte, clasele pot avea la implementare: 

e date şi metode caracterisitice fiecărui obiect din clasă (membri de tip instanţă), 

e date şi metode specifice clasei (membri de tip clasă). 

Astfel, clasa STIVA poate beneficia, în plus, şi de date ale clasei cum ar fi: numărul de 
stive generate, numărul maxim sau numărul minim de componente ale stivelor existente etc. 
Modificatorul static plasat la definirea unui membru al clasei face ca acela să fie un 
membru de clasă, nu unul de tip instanţă. Dacă în cazul membrilor nestatici, există câte un 
exemplar al membrului respectiv pentru fiecare instanţă a clasei, membrii statici sunt unici, 
fiind accesaţi in comun de toate instanţele clasei. Mai mult, membrii statici pot fi referiti fără a 
crea vreo instanţă a clasei respective. 


1.3. Supraincárcare 


Desi nu este o tehnicá specificá programárii orientatá obiect, ea creeazá un anumit 
context pentru metodele ce formeazá o clasá si modul in care acestea pot fi (ca orice 
subprogram) apelate. 

Prin supraincarcare se înțelege posibilitatea de a defini în acelaşi domeniu de 
vizibilitate? mai multe functii cu acelasi nume, dar cu parametri diferiti ca tip si/sau ca numár. 
Astfel ansamblul format din numele functiei si lista sa de parametri reprezintá o modalitate 
unicà de identificare numitä semnáturá sau amprentä. Supraincärcarea permite obtinerea 
unor efecte diferite ale apelului in contexte diferite?. 


| Datorită tehnicii de supraincárcare C++, Java si C# permit existenta mai multor constructori 

? Notiunile generale legate de vizibilitate se considerá cunoscute din programarea proceduralä. 
Aspectele specifice şi modificatorii de acces/vizibilitate pot fi studiati din documentatiile de referință CF. 

Capacitatea unor limbaje (este si cazul limbajului C£) de a folosi ca "nume" al unui 
subprogram un operator, reprezintá supraincärcarea operatorilor. Aceasta este o facilitate care 
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Apelul unei functii care beneficiazá, prin supraincárcare, de douá sau mai multe 
semnáturi se realizeazá prin selectia functiei a cárei semnäturä se potriveste cel mai bine cu 
lista de parametri efectivi (de la apel). 

Astfel, poate fi definită metoda "comandă on-line" cu trei semnături diferite: 
comanda_online (cod_prod) cu un parametru întreg (desemnând comanda unui singur 
produs identificat prin cod. prod. 
comanda online(cod prod,cantitate) cu primul parametru intreg si celalalt real 
comanda online(cod prod,calitate) cu primul parametru intreg si al-II-ilea caracter. 


1.4. Mostenire 


Pentru tipurile de date obiectuale class este posibilä o operatie de extindere sau 
specializare a comportamentului unei clase existente prin definirea unei clase noi ce 
mosteneste datele si metodele clasei de bazá, cu aceastä ocazie putänd fi redefiniti unii 
membri existenti sau adáugati unii membri noi. Operatia mai poartá numele de derivare. 

Clasa din care se mostenestea se mai numeste clasä de bazä sau superclasá. Clasa 
care mosteneste se numeste subclasá, clasä derivatà sau clasá descendentä. 

Ca si in Java, in C£ o subclasä poate mosteni de la o singurä superclasá, adicá avem 
de-a face cu mostenire simplá; aceeasi superclasá insä poate fi derivatä in mai multe 
subclase distincte. O subclasa, la randul ei, poate fi superclasa pentru o alta clasa derivata. 
O clasá de baza impreunä cu toate clasele descendente (direct sau indirect) formeaza o 
ierarhie de clase. In C£, toate clasele mostenesc de la clasa de bazá Object. 

In contextul mecanismelor de mostenire trebuie amintiti modificatorii abstract si sealed 
aplicati unei clase, modificatori ce obligá la si respectiv se opun procesului de derivare. Astfel, o 
clasá abstractä trebuie obligatoriu derivatá, deoarece direct din ea nu se pot obtine obiecte 
prin operatia de instantiere, in timp ce o clasa sigilata (sealed) nu mai poate fi derivata (e un 
fel de terminal in ierarhia claselor). O metodä abstractä este o metodá pentru care nu este 
definită o implementare, aceasta urmând a fi realizată în clasele derivate din clasa curentă”. 
O metodă sigilată nu mai poate fi redefinită în clasele derivate din clasa curentă. 


1.5. Polimorfism. Metode virtuale 


Folosind o extensie a sensului etimologic, un obiect polimorfic este cel capabil să ia 
diferite forme, să se afle în diferite stări, să aibă comportamente diferite. Polimorfismul 
obiectual? se manifestă în lucrul cu obiecte din clase aparţinând unei ierarhii de clase, unde, 
prin redefinirea unor date sau metode, se obțin membri diferiţi având însă acelaşi nume. 
Astfel, în cazul unei referiri obiectuale, se pune problema stabilirii datei sau metodei referite. 
Comportamentul polimorfic este un element de flexibilitate care permite stabilirea 
contextuală, în mod dinamică, a membrului referit. 

De exemplu, dacă este definită clasa numită PIESA (de şah), cu metoda nestatică 
muta (pozitie_initiala,pozitie_ finala), atunci subclasele TURN si PION trebuie 
să aibă metoda muta definită în mod diferit (pentru a implementa maniera specifică a 
pionului de a captura o piesă "en passant"). Atunci, pentru un obiect T, aparținând claselor 


"reduce" diferenţele dintre operarea la nivel abstract (cu DTA) şi apelul metodei ce realizează acestă 
operaţie la nivel de implementare obiectuală. Deşi ajută la sporirea expresivitätii codului, prin 
supraîncărcarea operatorilor şi metodelor se pot crea şi confuzii. 

* care trebuie să fie şi ea abstractă (virtuală pură, conform terminologiei din C++) 

5 deoarece tot aspecte polimorfice îmbracă şi unele tehnici din programarea clasică sau tehnica 
supraîncărcărcării funcţiilor şi operatorilor. 

Š Este posibil doar în cazul limbajelor ce permit “legarea întârziată”. La limbajele cu "legare 
timpurie", adresa la care se face un apel al unui subprogram se stabileşte la compilare. La limbajele 
cu legare întârziată, această adresa se stabileste doar in momentul rulării, putându-se calcula distinct, 
în funcţie de contextul în care apare apelul. 

Într-o altă concepție, metoda muta poate fi implementată la nivelul clasei PIESA şi redefinită 
la nivelul subclasei PION, pentru a particulariza acest tip de deplasare care capturează piesa peste 
care trece pionul în diagonală. 
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derivate din PIESA, referirea la metoda muta pare nedefinitä. Totusi mecanismele POO 
permit stabilirea, in momentul apelului, a clasei proxime càreia ii apartine obiectul T si 
apelarea metodei corespunzátore (mutare de pion sau turä sau altä piesä). 

Pentru a permite acest mecanism, metodele care necesitá o decizie contextualä (in 
momentul apelului), se decalrá ca metode virtuale (cu modificatorul virtual). In mod 
curent, in C£ modificatorului virtual al functiei din clasa de bazá, ii corespunde un 
specificator override al functiei din clasa derivatä ce redefineste functia din clasa de bazá. 

O metodä ne-virtuala nu este polimorfica si, indiferent de clasa careia ii apartine 
obiectul, va fi invocata metoda din clasa de bazá. 


1.6. Programare orientată obiect in CZ 


CA permite utilizarea OOP respectând toate principiile enunțate anterior. 

Toate componentele limbajului sunt într-un fel sau altul, asociate noțiunii de clasă. 
Programul însuşi este o clasă având metoda statică Main () ca punct de intrare, clasă ce nu 
se instantiazá. Chiar şi tipurile predefinite byte, int sau bool sunt clase sigilate derivate 
din clasa valueType din spaţiul System. Pentru a evita unele tehnici de programare 
periculoase, limbajul oferă tipuri speciale cum ar fi: interfețe şi delegări. Versiunii 2.0 a 
limbajului i s-a adăugat un nou tip: clasele generice, 


1.7. Declararea unei clase 


Sintaxa”: [atrib], [modificatori], class [nume clasá][:clasa de bază], [corp clasá], 


Atributele reprezintă informaţii declarative cu privire la entitatea definită. 

Modificatorii reprezintă o secvenţă de cuvinte cheie dintre: new public protected 

internal private (modificatori de acces) abstract sealed (modificatori de moştenire) 

Clasa de bază este clasa de la care moşteneşte clasa curentă şi poate exista o singură 

astfel de clasă de bază. Corpul clasei este un bloc de declarări ale membrilor clasei: 

constante (valori asociate clasei), câmpuri (variabile), tipuri de date definite de utilizator, 

metode (subprograme), constructori, un destructor, proprietăţi (caracteristici ce pot fi 

consultate sau setate), evenimente (instrumente de semnalizare), indexatori (ce permit 

indexarea instanţelor din cadrul clasei respective) şi operatori. 

e constructorii si destructorul au ca nume numele clasei proxime din care fac parte?” 

e metodele au nume care nu coincid cu numele clasei sau al altor membri (cu excepția 
metodelor, conform mecanismului de supraîncărcare) 

e metodele sau constructorii care au acelaşi nume trebuie să difere prin semnătură"! 

e se pot defini date şi metode statice (caracteristice clasei) şi un constructor static care se 
execută la initializarea clasei propriu-zise; ele formează un fel de "context" al clasei 

e se pot defini date şi metode nestatice (de instanţă) care se multiplică pentru fiecare 
instanță în parte în cadrul operaţiei de instantiere; ele formează contextele tuturor 
instanţelor clasei respective 

Exemplul următor defineşte o ierarhie de clase (conform figurii alăturate) 


public abstract class Copil 
ublic class Fetita: Copil : 
urs sealed class dc) PNE { } 

Modificatorul abstract este folosit pentru a desemna faptul ca nu se pot obtine 
obiecte din clasa Copil, ci numai din derivatele acesteia (Fetita, Baiat), iar modificatorul 
sealed a fost folosit pentru a desemna faptul ca nu se mai pot obtine clase derivate din 
clasa Baiat (de exemplu, subclasele Baiat cuminte şi Baiat rau) 


? echivalentrul claselor template din C++ 

3 [] din definiția schematică semnifică un neterminal, iar o semnifică o componentă opţională 
19 având în vedere că ele pot să facă parte dintr-o clasă interioară altei clase 

11 din semnătură nefäcänd parte specificatorii ref şi out asociați parametrilor 
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1.8. Constructori 


Sintaxa: 
[atrib]. [modificatori], [(nume clasá] ([listá param formali];) [: initializator], [corp constr]; 


Modificatori: public protected internel private extern 

Initializator: base((lista_param],), this((lista_param],) ce permite invocarea unui constructor 

anume’? înainte de executarea instrucţiunilor ce formează corpul constructorului curent. Dacă 

nu este precizat niciun initializator, se asociază implicit initializatorul base () . 

Corpul constructorului este format din instrucţiuni care se execută la crearea unui nou obiect al 

clasei respective (sau la crearea clasei, în cazul constructorilor cu modificatorul static). 

e potexista mai multi constructori care se pot diferenţia prin lista lor de parametri 

e constructorii nu pot fi mosteniti 

e daca o clasá nu are definit niciun constructor, se va asigna automat constructorul fara 
parametri al case de bazá (clasa object, dacá nu este precizatä clasa de bazä) 

Instantierea presupune declararea unei variabile de tipul clasei respective si initializarea 

acesteia prin apelul constructorului clasei (unul dintre ei, dacá sunt definiti mai multi) 

precedat de operatorul new. Acestea se pot realiza si simultan intr-o instructiune de felul: 

[Nume clasá] [nume obiect]|-new [Nume clasá] ([lista_param],) 
> Utilizarea unui constructor fárá parametri si a constructorului implicit in clasá derivatà 


public abstract class Copil 
( protected string nume; 
public Copil() (nume = Console.ReadLine();} //lainitializarea obiectului se citeste 
//de la tastatura un sir de caractere ce va reprezenta numele copilului 


} 
class Fetita:Copil {} 


Fetita f=new Fetita(); 
Copil c= new Copil(); //Pentru clasa Copil abstractá, s-ar fi obtinut eroare aici 


>  Supraîncărcarea constructorilor si definirea explicită a constructorilor în clase derivate 

public class Copil 

( protected string nume; //dată acceesibilă numai în interiorul clasei şi claselor derivate 
public Copil() (nume = Console.ReadLine() ; } 
public Copil(string s) {nume=s; } 

} 

class Fetita:Copil 

{ public Fetita(string s):base(s) (nume-"Fetita “+nume)?? 


public Fetita() {} //preia constructorul fără parametri din clasa de bază” 
//public Fetita(string s):base() {nume=s} 

} 

Copil cl= new Copil(); / / se citeste numele de la tastatură 


Copil c2= new Copil(“Codrina”); 
Fetita fl-new Fetita();Fetita f2-new Fetita("Ioana"); 


Existá douá motive pentru care definitia constructorului al treilea din clasa Fetita este gresità 
si de aceea este comentatä. Care sunt aceste motive? 


1.9. Destructor 


Sintaxa: [atrib], [extern], -[nume_clasá] () [corp destructor], 


Corpul destructorului este format din instructiuni care se executä la distrugerea unui 
obiect al clasei respective. Pentru orice clasä poate fi definit un singur constructor. Destructorii 


Din clasa de bazá (base) sau din clasa insási (this) 
13 Preia şi specializează constructorul al doilea din clasa de bază 
14 Este echivalent cu public Fetita () :base () {} 
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nu pot fi mosteniti. In mod normal, destructorul nu este apelat in mod explicit, deoarece 
procesul de distrugere a unui obiect este invocat si gestionat automat de Garbagge Collector. 


1.10. Metode 


Sintaxa: [atrib].[modificatori].[tip_returnat] [nume] ([listá param formali];) [corp metoda], 
Modificatori: new public protected internal private static virtual abstract 
sealed override extern!” 

Tipul rezultat poate fi un tip definit sau void. Numele poate fi un simplu identificator sau, in 
cazul in care defineste in mod explicit un membru al unei interfete, numele este de forma 
[nume interfata]. [nume metoda] 

Lista de parametri formali este o succesiune de declarári despártite prin virgule, declararea 
unui parametru având sintaxa: [atrib], [modificator], [tip] [nume] 

Modificatorul unui parametru poate fi ref (parametru de intrare şi ieşire) sau out (parametru 
care este numai de ieşire). Parametrii care nu au niciun modificator sunt parametri de intrare. 


Un parametru formal special este parametrul tablou cu sintaxa: [atrib], params [tip] [ 1 [nume]. 


e Pentru metodele abstracte şi externe, corpul metodei se reduce la un semn ; 

e Semnătura fiecărei metode este formată din numele metodei, modificatorii acesteia, 
numărul şi tipul parametrilor "ê 

e Numele metodei trebuie să difere de numele oricărui alt membru care nu este metodă. 

e Laapelul metodei, orice parametru trebuie să aibă acelaşi modificator ca la definire 

Invocarea unei metode se realizează prin sintagma [nume obiect].[nume metoda] (pentru 

metodele nestatice) şi respectiv [nume clasá].[nume metoda] (pentru metodele statice). 


> Definirea datelor şi metodelor statice corespunzătoare unei clase 
public class Copil 


( public const int nr max = 5; //constanta 
public static int nr_copii=0; //camp simplu (variabilă) 
static Copil[] copii=new Copil[nr max]; //cämp de tip tablou (variabilă) 
public static void adaug copil(Copil c) //metodä 
{ copii[nr copii++] = c; 


if (nr copii--nr max) throw new Exception("Prea multi copii"); 
) 
public static void afisare() //metodä 
{ 
Console.WriteLine("Sunt (0) copii:", nr copii); 
for (int i = 0; i«nr copii; i++) 


Console.WriteLine("Nr.(0). {1}", i+1, copii[il.nume); 
Teu 


) 


Fetita c = new Fetita();Copil.adaug copil(oc); 

referinta noului obiect se memoreazá in tabloul static copii (caracteristic clasei) si se 
incrementeazá data statică nr. copii 

Baiat c = new Baiat(); Copil.adaug copil(oc); 

Copil c = new Copil(); Copil.adaug copil(oc); 

Copil.afisare();//se afigeazá o listá cu numele celor 3 copii 


15 Poate fi folosit cel mult unul dintre modificatorii static, virtual sl override ; nu pot apárea 
impreunä new si override, abstract nu poate sà apará cu niciunul dintre static, virtual, sealed, extern; 
private nu poate sä apará cu niciunul dintre virtual, override si abstract; seald obligä si la override 

Din semnáturá (amprentá) nu fac parte tipul returnat, numele parametrilor formali si nici 
specificatorii ref si out. 

17 Se are în vedere şi constructorul fără parametri definit şi preluat implicit în subclasele din cadrul 
primului exemplu din subcapitolul 1.8: public Copil() (nume = Console.ReadLine();} 
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> Definirea datelor si metodelor nestatice corespunzátoare clasei Copil si claselor derivate 
public class Copil 
{ 


public string nume; 


public virtual void se joaca() virtual > se poate suprascrie la derivare 
{Console.WriteLine ("{0} se joaca.", this.nume);] 
public void se joaca(string jucaria) /Inu permite redefinire"? 
{Console.WriteLine("{0} se joaca cu {1}.", this.nume, jucaria);) 
} /Isupraîncărcarea metodei se_joaca 
class Fetita:Copil 
{ public override void se joaca() //redefinire > comportament polimorfic 


{Console.WriteLine("{0} leagana papusa.",this.nume);) 


class Baiat:Copil 
{ public override void se joaca() 
{Console.WriteLine("{0} chinuie pisica.",this.nume) ; } 


Fetita c = new Fetita();c.se joaca("pisica");c.se joaca(); //polimorfism 
Baiat c = new Baiat();c.se joaca("calculatorul");c.se joaca(); //polimorfism 
Copil c = new Copil();c.se joaca(); //polimorfism 
Pentru a evidentia mai bine comportamentul polimorfic, propunem secvenţa 
urmátoare in care nu se stie exact ce este obiectul copii[i] (de tip Copil, Fetita sau Baiat?): 


for (int i20; i«nr copii; i++) copii[i].se_joaca; 
1.11. Proprietati 


Proprietatea este un membru ce permite accesul controlat la datele-membru ale clasei. 
Sintaxa: [atrib], [modificatori], [tip] [(nume proprietate] ([[metode de acces]; 


Observatiile privind modificatorii si numele metodelor sunt valabile si in cazul proprietátilor. 
Metodele de acces sunt douä: set si get. Dacá proprietatea nu este abstractä sau externá, 
poate sà apará una singurá dintre cele douá metode de acces sau amándouá, in orice ordine. 
Este o manierá de lucru recomandabilä aceea de a proteja datele membru (cämpuri) ale 
clasei, definind instrumente de acces la acestea: pentru a obtine valoarea cámpului respectiv 
(get) sau de a memora o anumitä valoare in cámpul respectiv (set). Dacá metoda de acces 
get este perfect asimilabilà cu o metodá ce retuneazá o valoare (valoarea datei pe care 
vrem s-o obtinem sau valoarea ei modificata conform unei prelucrári suplimentare specifice 
problemei in cauzá), metoda set este asimilabilà cu o metodä care un parametru de tip 
valoare (de intrare) si care atribuie (sau nu, in functie de context) valoarea respectiva 
cämpului. Cum parametrul corespunzátor valorii transmise nu apare in structura sintacticá a 
metodei, este de stiut cà el este implicit identificat prin cuvántul value. Dacá se supune unor 
condiții specifice problemei, se face o atribuire de felul câmp=value. 
> Definirea în clasa Copil a proprietăţii Nume, corespunzătoare câmpului protejat ce reţine, 
sub forma unui şir de caractere, numele copilului respctiv. Se va observă că proprietatea 


este moştenită şi de clasele derivate Fetita si Báiat'?. 
public class Copil 
Ait z 
string nume; // este implicit protected 
public string Nume //proprietatea Nume 
( get 
{ if (char.IsUpper(nume[0]))return nume; else return nume.ToUpper ();) 
set ( nume = value; } 


18 Decât cu ajutorul modificatorului new pentru metoda respectivă în clasa derivată 
19 Desigur că proprietatea care controlează accesul la câmpul identificat prin nume se poate 
numi cu totul altfel (proprietatea Nume fiind usor de confundat cu câmpul de date nume). 
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public Copil() (Nume = Console.ReadLine();] /Imetoda set 


} 
class Fetita:Copil 
{ public override void se_joaca() 


(Console.WriteLine("(0) leagana papusa.",this.Nume);) /Imetoda get 
29 


1.12. Evenimente si delegari 


Evenimentele sunt membri ai unei clase ce permit clasei sau obiectelor clasei să facă 
notificări, adică să anunţe celelalte obiecte asupra unor schimbări petrecute la nivelul stării lor. 
Clasa furnizoare a unui eveniment publică (pune la dispoziţia altor clase) acest lucru printr-o 
declarare event care asociază evenimentului un delegat, adică o referință către o funcţie 
necunoscută căreia i se precizează doar antetul, funcția urmând a fi implementată la nivelul 
claselor interesate de evenimentul respectiv. Este modul prin care se realizează comunicarea 
între obiecte. Tehnica prin care clasele implementează metode (handler-e) ce răspund la 
evenimente generate de alte clase poartă numele de tratare a evenimentelor. 


Sintaxa: [atrib], [modificatori], event [tip delegat] [nume] 
Modificatorii permisi sunt aceiasi ca si la metode. 


Tipul delegat este un tip de date ca oricare altul, derivat din clasa sigilatà Delegate, din 
spatiul System. Definirea unui tip delegat se realizeazá prin declararea: 


[atrib], [modificatori], delegate [tip rezultat] [nume delegat] ([listá param formali];) 


Un delegat se poate defini si in afara clasei generatoare de evenimente si poate servi si altor 
scopuri in afara tratárii evenimentelor. Prezentám in continuare un exemplu. 


De exemplu, daca dorim sa definim o metoda asociata unui vector de numere intregi, 
metodá ce verificä dacä vectorul este o succesiune "bine aranjatä” (orice douá valori succesive 


respectá o anumita regula), o implementare "genericá" se poate realiza folosind delegari: 
public delegate bool pereche ok(object tl, object t2); 


public class Vector 
{ public const int nmax = 4; 
public int[] v=new int [nmax]; 
public Vector () 
{ Random rand = new Random(); 
for (int i = 0; i < nmax; i++) v[i] = rand.Next (0,5); 
} 
public void scrie() 
{ for (int i = 0; i < nmax; i++) Console.Write("(0), ", v[il); 
Console.WriteLine(); 
} 
public bool aranj(pereche_ok ok)//ok e o delegare către o funcţie necunoscută 
{ for (int i = 0; i < nmax-1; i++) 
if (!ok(v[i], v[i + 1])) return false; 
return true; 
} 
} 
Dacă in clasa-program” se adugă funcţiile (exprimând două “reguli de aranjare” posibile) 
public static bool fl(object tl, object t2) 


{if ((int)t1 >= (int)t2) return true;else return false;} 
public static bool f2(object tl, object t2) 
{if ((int)t1 <= (int)t2) return true;else return false;} 


atunci o secventä de prelucrare aplicativa ar putea fi: 


? De observat cá in exemplul anterior (subcapitolul 1.10), cámpul nume era declarat public, 
pentru a permite accesul "general" la cámpul respectiv de date. lar metodele si constructorii foloseau 
identificatorul nume si nu proprietatea Nume. 

2! Independent de definiţia clasei Vector 
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static void Main(string[] args) 
{ Vector x; 
do í 
x =new Vector();x.scrie(); 
if (x.aranj(fl))Console.WriteLine ("Monoton descrescator"); 
if (x.aranj(f2))Console.WriteLine("Monoton crescator"); 


) while (Console.ReadKey (true) .KeyCar!="\x001B’); //Escape 


) 

Revenind la evenimente, descriem pe scurt un exemplu teoretic de declarare si tratare a 
unui eveniment. În clasa vector se consideră cà interschimbarea valorilor a două 
componente ale unui vector e un eveniment de interes pentru alte obiecte sau clase ale 
aplicaţiei. Se defineşte un tip delegat TD (să zicem) cu nişte parametri de interes? şi un 
eveniment care are ca asociat un delegat E (de tip TD)**. Orice obiect x din clasa Vector are 
un membru E (initial null. O clasă C interesată sa fie instiintata cand se face vreo 
interschimbare într-un vector pentru a genera o animaţie (de exemplu), va implementa o 
metodă M ce realizează animația şi va adăuga pe M (prin intermediul unui delegat) la x . E", 
Cumulând mai multe astfel de referințe, x.E ajunge un fel de listă de metode (handlere). În 
clasa Vector, în metoda sort, la interschimbarea valorilor a două componente se invocă 
delegatul E. Invocarea lui E realizaeză de fapt activearea tuturor metodelor adăugate la E. 


Care credeți ca sunt motivele pentru care apelam la evenimente în acest caz, când pare 
mult mai simplu să apelăm direct metoda M la orice interschimbare? 


1.13. Interfete 


Interfetele sunt foarte importante in programarea orientatä pe obiecte, deoarece permit 
utilizarea polimorfismului intr-un sens mai extins.O interfata este o componenta a aplicatiei, 
asemánátoare unei clase, ce declará prin membrii sái (metode, proprietáti, evenimente si 
indexatori) un "comportament" unitar aplicabil mai multor clase, comportament care nu se 
poate defini prin ierarhia de clase a aplicatiei. 

De exemplu, dacá vom considera arborele din figura urmátoare, in care AVERE este o 
clasá abstractá, iar derivarea claselor a fost conceputä urmärind proprietátile comune ale 
componentelor unei averi, atunci o clasá VENIT nu este posibilä, deoarece ea ar mosteni de 
la toate clasele evidentiate, iar mostenirea multiplá nu este admisá in C£. 


AVERE 
Proprietate x Bam | 


Neproductiv Altul 


VENITURI 
(din produse, din 


De folosintà chirii, din dobánzi, 
Fr 
inet | as 


? De exmplu indicii componentelor interschimbate 
? A se observa cá evenimentul in sine este anonim, doar delegatul asociat are nume 
24 intr-o atribuire de felulx.E+=new [tip delegat] (M) 
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Pentru metodele din cadrul unei interfete nu se dà nici o implementare, ci sunt pur si simplu 
specificate, implementarea lor fiind furnizatä de unele dintre clasele aplicației”. Nu există 
instantiere în cazul interfetelor, dar se admit derivări, inclusiv mosteniri multiple. 

În exemplul nostru, se poate defini o interfață VENIT care să conţină antetul unei 
metode calc (să zicem) pentru calculul venitului obţinut, fiecare dintre clasele care 
implementează interfața VENIT fiind obligată să furnizeze o implementare (după o formulă 
de calcul specifică) pentru metoda calc din interfaţă. Orice clasă care doreşte să adere la 
interfață trebuie să implementeze toate metodele din interfaţă. Toate clasele care moştenesc 
dintr-o clasă care implementează o interfață moştenesc, evident, metodele respective, dar le 
pot şi redefini (de exemplu, clasa Credit_acordat redefineşte metoda calc din clasa Investitie, 
deoarece formula de calcul implementată acolo nu i se "potriveste" şi ei?9). 

De exemplu, dacă presupunem că toate clasele subliniate implementează interfața 
VENIT, atunci pentru o avere cu acțiuni la două firme, un imobil închiriat si o depunere la 
bancă, putem determina venitul total: 


Actiune actl = new Actiune();Actiune act2 = new Actiune); 

I inchiriat casa = new I inchiriat ();Depunere dep-new Depunere); 
Venit [] venituri = new Venit () [4]; 

venituri [0] = actl; venituri[1] = act2; 


venituri [2] casa; venituri[3] dep; 


int t=0; 
for(i=0;i<4;i++) t+=v[i].calc(); 

Găsiţi două motive pentru care interfața VENIT şi rezovarea de mai sus oferă o soluţie 
mai bună decât: t=actl.calc()+act2.calc()+casa.calc()+dep.calc(). 


1.14. Fire de execuţie 


Programarea prelucrărilor unei aplicaţii pe mai multe fire de execuţie (multithreading) 
presupune "descompunerea" ansamblului de prelucrări în secvențe, unele dintre ele 
"planificändu-se” a fi prelucrate paralel (cvasi-simultan) de către procesor în vederea utilizării 
eficiente a acestuia. Citire b citire a 


_ Schema alaturata este o posibila Zea:Y U<CZ-X 
planificare a procesului de calcul al 
expresiei a+(b+c)-b+b, unde a, b si c sunt 


nişte matrice pătrate ale căror  CĦ"ec — X€b«b Y€b*c 
componente se găsesc în fişiere separate. 

În orice punct al prelucrării de pe un fir de execuţie se poate genera un nou fir (thread) 
căruia i se asociază un subprogram cu ajutorul unui delegat. În exemplul următor, care 
utilizează spaţiul System. Threading, afişarea succesivă a unor secvențe de 1 şi de 2 
demonstrază "comutarea" executării de pe un fir pe altul la intervale relativ constante de timp: 
static void scrie2() 

{ for (int i = 1; i «300; i++)Console.Write('2');) 
static void Main(string[] args) 
( ThreadStart delegat = new ThreadStart (scrie2); 
Thread fir = new Thread(delegat); 
fir.Start(); 
for (int i = l; i <= 500; i++) Console.Write('1'); 
Console.ReadKey () ; } 

Spaţiul Threading mai oferă facilităţi de schimbare a prioritätilor prelucrărilor din fire 
paralele, de delimitare a secventelor critice, de asteptare si semnalizare folosind semafoare 
etc. O clasá sigilatä folositá curent in aplicatii (Timer) permite implementarea unui ceas care 
functioneazá pe un fir paralel cu aplicatia curentä si care, la intervale de timp ce se pot seta, 
genereazá un eveniment (Tick) "sesizat" si exploatat de prelucrarea din firul principal. 


25 Acele clase care "aderá" la o interfață spunem că "implementeazá” interfața respectivă 
?? Dacă în sens polimorfic spunem cá Investitie este si de tip Bani si de tip Avere, tot asa putem 
spune cá o clasá care implementeazá interfata VENIT si clasele derivate din ea sunt si de tip VENIT 
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2. Platforma .NET 
2.1. Prezentare 


NET este un cadru (framework) de dezvoltare software unitará care permite realizarea, 
distribuirea si rularea aplicatiilor-desktop Windows si aplicatiilor WEB. 

Tehnologia NET pune laolalta mai multe tehnologii (ASP, XML, OOP, SOAP, WDSL, 
UDDI) şi limbaje de programare (VB, C++, C£, J#) asigurând totodată atât portabilitatea 
codului compilat între diferite calculatoare cu sistem Windows, cât şi reutilizarea codului în 
programe, indiferent de limbajul de programare utilizat. 

NET Framework este o componentă livrată înpreună cu sistemul de operare Windows. 
De fapt, .NET 2.0 vine cu Windows Server 2003 şi Windows XP SP2 şi se poate instala pe 
versiunile anterioare, până la Windows 98 inclusiv; .NET 3.0 vine instalat pe Windows Vista şi 
poate fi instalat pe versiunile Windows XP cu SP2 şi Windows Server 2003 cu minimum SP1. 
Pentru a dezvolta aplicatii pe platforma .NET este bine sa avem 3 componente esenţiale: 

e un set de limbaje (C£, Visual Basic NET, J£, Managed C++, Smalltalk, Perl, Fortran, 
Cobol, Lisp, Pascal etc), 
un set de medii de dezvoltare (Visual Studio .NET, Visio), 
şi o bibliotecă de clase pentru crearea serviciilor Web, aplicaţiilor Web şi aplicaţiilor 
desktop Windows. 

Când dezvoltăm aplicaţii .NET, putem utiliza: 

e Servere specializate - un set de servere Enterprise .NET (din familia SQL Server 2000, 
Exchange 2000 etc), care pun la dispoziţie funcţii de stocare a bazelor de date, email, 
aplicaţii B2B (Bussiness to Bussiness — comerţ electronic între partenerii unei afaceri). 

e Servicii Web (în special comerciale), utile în aplicaţii care necesită identificarea 
utilizatorilor (de exemplu, NET Passport - un mod de autentificare folosind un singur 
nume şi o parolă pentru toate ste-urile vizitate) 

e Servicii incluse pentru dispozitive non-PC (Pocket PC Phone Edition, Smartphone, 
Tablet PC, Smart Display, XBox, set-top boxes, etc.) 


2.2. .NET Framework 


Componenta .NET Framework stă la baza tehnologiei .NET, este ultima interfaţă între 
aplicaţiile .NET şi sistemul de operare şi actualmente conţine: 

e Limbajele C£, VB.NET, C++ si J#. Pentru a fi integrate în platforma NET toate aceste 
limbaje respectă nişte specificații OOP numite Common Type System (CTS). Ele au 
ca elemente de bază: clase, interfeţe, delegări, tipuri valoare şi referință, iar ca 
mecanisme: moştenire, polimorfism şi tratarea excepțiilor. 

e Platforma comună de executare a programelor numită Common Language Runtime 
(CLR), utilizată de toate cele 4 limbaje. 

e Ansamblul de biblioteci necesare în realizarea aplicaţiilor desktop sau Web numit 
Framework Class Library (FCL). 


Arhitectura NET Framework 
Servicii WEB Formulare 


Data and XML classes 


Componenta .NET Framework este (ADO.NET, SQL, XML etc.) 3 
formatá din compilatoare, biblioteci si a 
alte executabile utile in rularea Framework Base Classes 

aplicaţiilor NET, Fisierele (IO, securitate, fire de executie, colectii etc.) 
corespunzátoare se aflá, in general, 

in directorul WINDOWS\Microsoft. Common Language Runtime CLR 
NET\Framework\V2.0.... (execeptii, validäri de tipuri,compilatoare JIT) 


(corespunzätor versiunii instalate) 
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2.3. Compilarea programelor 


Un program scris îintr-unul dintre limbajele NET conform Common Language 
Specification (CLS) este compilat in Microsoft Intermediate Language (MSIL sau IL). Codul 
astfel obtinut are extensia exe, dar nu este direct executabil, ci respectä formatul unic MSIL. 

CLR include o masinä virtualà asemánátoare cu o masina Java, ce executa 
instructiunile IL rezultate in urma compilärii. Masina foloseste un compilator special JIT (Just 
In Time). Compilatorul JIT analizeazá codul IL corespunzátor apelului unei metode si 
produce codul masiná adecvat si eficient. El recunoaste secventele de cod pentru care s-a 
obtinut deja codul masiná adecvat permitánd reutilizarea acestuia fárá recompilare, ceea ce 
face ca, pe parcursul rulării, aplicaţiile NET să fie din ce in ce mai rapide. 

Faptul cá programul IL produs de diferitele limbaje este foarte asemänätor are ca 
rezultat interoperabilitatea intre aceste limbaje. Astfel, clasele si obiectele create intr-un 
limbaj specific NET pot fi utilizate cu succes într-un program scris in alt limbaj. 

În plus, CLR se ocupă de gestionarea automată a memoriei (un mecanism 
implementat in platforma .NET fiind acela de eliberare automatá a zonelor de memorie 
asociate unor date devenite inutile — Garbage Collection). 

Ca un element de portabilitate, trebuie spus cá CTS are o arhitecturá ce permite 
rularea aplicaţiilor NET, în afară de Windows, si pe unele tipuri de Unix, Linux, Solaris, Mac 
OS X si alte sisteme de operare (http://www.mono-project.com/Main Page ). 


3. Limbajul CZ 
3.1. Caracterizare 


Limbajul C£ fost dezvoltat de o echipá restränsä de ingineri de la Microsoft, echipä din 
care s-a evidentiat Anders Hejlsberg (autorul limbajului Turbo Pascal si membru al echipei 
care a proiectat Borland Delphi). 

C# este un limbaj simplu, cu circa 80 de cuvinte cheie, si 12 tipuri de date predefinite. 
El permite programarea structuratá, modularä si orientatá obiectual, conform perceptelor 
moderne ale programarii profesioniste. 

Principiile de bază ale programării pe obiecte (INCAPSULARE, MOSTENIRE, 
POLIMORFISM) sunt elemente fundamentale ale programării C#. În mare, limbajul 
moşteneşte sintaxa şi principiile de programare din C++. Sunt o serie de tipuri noi de date 
sau funcțiuni diferite ale datelor din C++, iar în spiritul realizării unor secvenţe de cod sigure 
(safe), unele funcțiuni au fost adăugate (de exemplu, interfeţe si delegări), diversificate (tipul 
struct), modificate (tipul string) sau chiar eliminate (moştenirea multiplă şi pointerii către 
funcţii). Unele funcțiuni (cum ar fi accesul direct la memorie folosind pointeri) au fost 


păstrate, dar secvențele de cod corespunzătoare se consideră "nesigure". 


3.2. Compilarea la linia de comandă 


Se pot dezvolta aplicaţii .NET şi fără a dispune de mediul de dezvoltare Visual Studio, ci 
numai de .NET SDK (pentru 2.0 şi pentru 3.0). În acest caz, codul se scrie în orice editor de 
text, fişierele se salvează cu extensia cs, apoi se compilează la linie de comandă. 

Astfel, se scrie în Notepad programul: 
using System; 
class primul 
{ 

static void Main() 
{ Console.WriteLine ("Primul program"); 
Console.ReadKey (true); 


} 
} 
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Dacá se salveazá fisierul primul.cs, in directorul WINDOWS\Microsoft .NET\Framework\V2.0, 
atunci scriind la linia de comandá: csc primul.cs se va obtine fisierul primul.exe direct 
executabil pe o platformá .NET. 

3.3. Crearea aplicatiilor consola 


Pentru a realiza aplicatii in mediul de dezvoltare Visual Studio, trebuie sá instalám o 
versiune a acestuia, eventual versiunea free Microsoft Visual C# 2005 Express Edition de 
la adresa http://msdn.microsoft.com/vstudio/express/downloads/default.aspx. Pentru inceput, 
putem realiza aplicatii consolá (ca si cele din Borland Pascal sau Borland C). 

După lansare, alegem 
opțiunea New Project din |... 

meniul File. In fereastra de visual Studio installed templates 
dialog (vezi figura), selectăm 


pictograma Console = ou B uu NM A 


Windows Class Library Console Empty Project Screen Saver Movie 


Application, dupa care, la Application Application Starter Kit Collecti... 
Name, introducem numele 
aplicației noastre. 


New Project 


. My Templates 


Fereastra in care scriem Search Online 
programul se numeşte | "w 
implicit Programs.cs si se 
poate modifica prin salvare 
explicitä (Save As). Extensia 
cs provine de la C Sharp. 


A project for creating a command-line application 


Name: ConsoleApplication1 


class Program 


In scrierea programului suntem asistati i 


de IntelliSense, ajutorul contextual. 
Compilarea programului se realizează cu 
ajutorul opțiunii Build Solution (F6) din meniul 
Build. Posibilele erori de compilare sunt listate } 
in fereastra Error List. Efectuänd dublu click pe 
fiecare eroare in parte, cursorul din program se e IEqualityComparer<> 
pozitioneazà pe linia continánd eroarea. -o IEquatable<> 


Rularea programului se poate realiza in fay 


static void Main(string[] args) 
{ 
i 
-5 IEnumerable <> 
-O IEnumerator <> 


mai multe moduri: rapid fără asistență de -O IFormatProvider 
depanare (Start Without Debugging Shift+F5) , -© IFormattable 
rapid cu asistență de depanare (Start -ð Liste» 

= in 
Debugging F5 sau cu butonul ` din bara de 2) indexer 


instrumente), rulare pas cu pas (Step Into F11 
si Step Over F12) sau rulare rapida pana la linia 
marcată ca punct de întrerupere (Toggle [Ee tug rn 


Debug | Data Tools Window Community 


Breakpoint F9 pe linia respectivá si apoi Start 
Debugging F5). Incetarea urmáririi pas cu pas ; 
(Stop Debugging Shift+F5) permite iesirea din Windows d 
modul depanare si revenirea la modul normal de b Start Debugging F5 
lucru. Toate optiunile de rulare si depanare se 
gásesc in meniul Debug al meniului. 

Fereastra de cod si ferestrele auxiliare ce ne Exceptions... Ctrl+D, E 
ajutá in etapa de editare pot fi vizualizate alegänd 
opțiunea corespunzătoare din meniul View. 
Ferestrele auxiliare utile în etapa de depanare se |! Step Over F10 
pot vizualiza alegând opţiunea corespunzătoare Toggle Breakpoint F9 
din meniul Debug/Windows. 


Start Without Debugging Ctri+FS 


Step Into Fil 
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3.4. Structura unui program C# 
S 


Dir 


incepem cu exemplul clasic "Hello World” adaptat la limbajul C#: 


using System; 


namespace HelloWorld 
{ 
class Program 
{ 
static void Main() 


{ 
9 Console.WriteLine ("Hello World!"); 


O Jo OG QO N P 


O aplicatie C# este formatà din una sau mai multe clase, grupate in spatii de nume 
(namespaces). Un spatiu de nume cuprinde mai multe clase cu nume diferite avánd 
functionalitáti inrudite. Douá clase pot avea acelasi nume cu conditia ca ele sá fie definite in 
spatii de nume diferite. Ín cadrul aceluiasi spatiu de nume poate apárea definitia unui alt 
spatiu de nume, caz in care avem de-a face cu spatii de nume imbricate. O clasá poate fi 
identificatá prin numele complet (nume precedat de numele spatiului sau spatiilor de nume 
din care face parte clasa respectivă, cu separatorul punct). În exemplul nostru, 
HelloWorld.Program este numele cu specificaţie completă al clasei Program. 

O clasă este formată din date şi metode (funcţii). Apelarea unei metode în cadrul clasei 
în care a fost definită aceasta presupune specificarea numelui metodei. Apelul unei metode 
definite în interiorul unei clase poate fi invocată şi din interiorul altei clase, caz în care este 
necesară specificarea clasei şi apoi a metodei separate prin punct. Dacă în plus, clasa 
aparține unui spațiu de nume neinclus în fişierul curent, atunci este necesară precizarea 
tuturor componentelor numelui: spatiu.clasä.metodä sau spatiu.spatiu.clasä.metodä etc. 

În fişierul nostru se află două spatii de nume: unul definit (HelloWorld) şi unul extern 
inclus prin directiva using (System). Console.Writeln reprezintă apelul metodei Writeln 
definită în clasa Console. Cum în spaţiul de nume curent este definită doar clasa Program, 
deducem că definiţia clasei Console trebuie să se găsească în spaţiul System. 

Pentru a facilita cooperarea mai multor programatori la realizarea unei aplicaţii 
complexe, există posibilitatea de a segmenta aplicaţia în mai multe fişiere numite 
assemblies. Într-un assembly se pot implementa mai multe spatii de nume, iar parti ale unui 
aceeaşi spaţiu de nume se pot regăsi in mai multe assembly-uri. Pentru o aplicaţie consolă, 
ca şi pentru o aplicație Windows de altfel, este obligatoriu ca una (şi numai una) dintre clasele 
aplicaţiei să conţină un „punct de intrare” (entry point), şi anume metoda (funcţia) Main. 


Să comentăm programul de mai sus: 
linia 1: este o directivă care specifică faptul că se vor folosi clase incluse în spaţiul de nume 
System. În cazul nostru se va folosi clasa Console. 
linia 3: spaţiul nostru de nume 
linia 5: orice program C# este alcătuit din una sau mai multe clase 
linia 7: metoda Main, „punctul de intrare” în program 
linia 9: clasa Console, amintită mai sus, este folosită pentru operaţiile de intrare/ieşire. Aici 


se apelează metoda WriteLine din acestă clasă, pentru afişarea mesajului dorit pe ecran. 


3.5. Sintaxa limbajului 


Ca şi limbajul C++ cu care se înrudeşte, limbajul C# are un alfabet format din litere 
mari şi mici ale alfabetului englez, cifre şi alte semne. Vocabularul limbajului este format din 
acele “simboluri”? cu semnificaţii lexicale în scrierea programelor: cuvinte (nume), expresii, 


separatori, delimitatori şi comentarii. 


27 Este un termen folosit un pic echivoc si provenit din traduceriea cuvântului "token" 
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Comentarii 
e comentariu pe un rând prin folosirea // Tot ce urmează după caracterele // sunt 
considerate, din acel loc, până la sfârşitul rândului drept comentariu 
// Acesta este un comentariu pe un singur rand 
e comentariu pe mai multe rânduri prin folosirea /* şi */ Orice text cuprins între 
simbolurile menţionate mai sus se consideră a fi comentariu. Simbolurile /* reprezintă 
începutul comentariului, iar */ sfârşitul respectivului comentariu. 
/* Acesta este un 


comentariu care se 
intinde pe mai multe randuri */ 


Nume 
Prin nume dat unei variabile, clase, metode etc. înțelegem o succesiune de caractere 
care îndeplineşte următoarele reguli: 
+ numele trebuie să înceapă cu o literă sau cu unul dintre caracterele " " si "en" 
e primul caracter poate fi urmat numai de litere, cifre sau un caracter de subliniere; 
e numele care reprezintă cuvinte cheie nu pot fi folosite în alt scop decât acela 
pentru care au fost definite 
e cuvintele cheie pot fi folosite în alt scop numai dacă sunt precedate de @ 
e două nume sunt distincte dacă diferă prin cel putin un caracter (fie el şi literă mică 
ce diferă de aceeaşi literă majusculă) 


Convenții pentru nume: 
e in cazul numelor claselor, metodelor, a proprietăţilor, enumerarilor, interfetelor, 


spaţiilor de nume, fiecare cuvânt care compune numele începe cu majusculă 
« in cazul numelor variabilelor dacă numele este compus din mai multe cuvinte, 
primul începe cu minusculă, celelalte cu majusculă 


Cuvinte cheie în C# 


abstract as base bool break 

byte case catch char checked 
class const continue decimal default 
delegate do double else enum 
event explicit extern false finally 
fixed float for foreach goto 

if implicit in int interface 
internal is lock long namespace 
new null object operator out 
override params private protected public 
readonly ref return sbyte sealed 
short sizeof stackalloc | static string 
struct switch this throw true 

try typeof uint ulong unchecked 
unsafe ushort using virtual void 
volatile while 


Simbolurile lexicale reprezentând constante, regulile de formare a expresiilor, 
separatorii de liste, delimitatorii de instrucţiuni, de blocuri de instrucțiuni, de şiruri de 
caractere etc. sunt în mare aceiaşi ca şi în cazul limbajului C++. 


3.6. Tipuri de date 


În C# există două categorii de tipuri de date: 
° tipuri valoare 
= tipul simple: byte, char, int, float etc. 
= tipul enumerare - enum 
= tipul structură - struct 
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tipuri referintá 

tipul clasá - class 

tipul interfatá - interface 
tipul delegat - delegate 
tipul tablou - array 


Toate tipurile de date sunt derivate din tipul System.Object 

Toate tipurile valoare sunt derivate din clasa System.ValueType, derivatà la rándul ei 
din clasa Object (alias pentru System.Object). 

Limbajul CZ contine un set de tipuri predefinite (int, bool etc.) si permite definirea 
unor tipuri proprii (enum, struct, class etc.). 


Tipuri simple predefinite 


Tip Descriere Domeniul de valori 
object | rádácina oricárui tip 
string secventa de caractere Unicode 
sbyte tip intreg cu semn, pe 8 biti -128; 127 
short tip intreg cu semn, pe 16 biti -32768; 32767 
int tip intreg cu semn pe, 32 biti -2147483648; 21447483647 
long tip intreg cu semn, pe 64 de biti -9223372036854775808; 
9223372036854775807 
byte tip intreg fárá semn, pe 8 biti 0; 255 
ushort | tip intreg fárá semn, pe 16 biti 0; 65535 
uint tip intreg fárá semn, pe 32 biti 0; 4294967295 
ulong tip intreg fárá semn, pe 64 biti 0; 18446744073709551615 
float tip cu virgulä mobila, simplä precizie, pe | -3.402823E+38; 3.402823E+38 
32 biti (8 pentru exponent, 24 pentru 
mantisá) 
double | tip cu virgulă mobilă, dublă precizie, pe | -1.79769313486232E+308; 
64 biti (11 pentru exponent, 53 -mantisa) | 1.79769313486232E+308 
bool tip boolean - 
79228162514264337593543950335; 
79228162514264337593543950335 
char tip caracter din setul Unicode, pe 16 biti 
decimal | tip zecimal, pe 128 biti (96 pentru 


mantisá), 28 de cifre semnificative 


O valoare se asigneazá dupá urmátoarele reguli: 


Sufix Tip 

nu are int, uint, long, ulong 
u, U uint, ulong 
L, L long, ulong 
ul, lu, Ul, 1U, UL, LU, Lu | ulong 

Exemple: 
string s = "Salut!" float g = 1.234F; 
long a = 10; double h = 1.234; 
long b = 13L; double i = 1.234D; 
ulong c = 12; bool condl = true; 
ulong d = 15U; bool cond2 = false; 
ulong e = 16L; decimal j = 1.234M; 
ulong f 17UL; 
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Tipul enumerare 


Tipul enumerare este un tip de finit de utilizator. Acest tip permite utilizarea numelor 
care, sunt asociate unor valori numerice. Toate componentele enumerate au un acelasi tip 
de bazä intreg. In cazul in care, la declarare, nu se specificä tipul de bazá al enumeràšrii, 
atunci acesta este considerat implicit int. 

Declararea unui tip enumerare este de forma: 

enum [Nume tip] [: Tip], 


{ 


[identificatorl] [=valoare],, 


[identificatorn] [=valoare], 
} 
Observatii: 
e În mod implicit valoarea primului membru al enumerärii este O, iar fiecare variabilă care 
urmeazä are valoarea (implicitä) mai mare cu o unitate decät precedenta. 
e Valorile folosite pentru initializári trebuie sá facă parte din domeniul de valori declarat al 
tipului 
e Nu se admit referințe circulare: 
enum ValoriCirculare 
{ 
a = b, 
b 
) 
Exemplu: 


using System; 
namespace tipulEnum 
{ 
class Program 
{ 
enum lunaAnului 
{ 
Ianuarie = 1, 
Februarie, Martie, Aprilie, Mai, Iunie, Iulie, 
August, Septembrie, Octombrie, Noiembrie, Decembrie 


) 
static void Main(string[] args) 
( 
Console.WriteLine("Luna Mai este a ", 
(int)lunaAnului.Mai + "a luna din an."); 
Console.ReadLine(); 


} 
} 
In urma rulárii programului se afiseazä mesajul : 
Luna Mai este a 5 a luna din an. 


Tablouri 


Declararea unui tablou unidimensional: 

Tip[] nume; 

Prin aceasta, nu se alocä spatiu pentru memorare. Pentru a putea retine date in 
structura de tip tablou, este necesarä o operatie de instantiere: 

nume = new Tip[NumarElemente]; 

Declararea, instantierea si chiar initializarea tabloului se pot face in aceeasi instructiune: 


Exemplu: 
int[] v new int[] {1,2,3}; sau 
int[] v = {1,2,3}; //new este implicit 
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În cazul tablourilor cu mai multe dimensiuni facem distincţie între tablouri regulate si 
tablouri neregulate (tablouri de tablouri) 


Declarare în cazul tablourilor regulate bidimensionale: 
Tip[,] nume; 

Intantiere: 

nume = new Tip[Linii,Coloane]; 

Acces: 

nume[indicel,indice2] 

Exemple: 


int[,] mat new int[,] {{1,2,3},{4,5,6},{7,8,9}}; Sau 
int[,] mat - {{1,2,3},{4,5,6},{7,8,9}}; 


Declarare in cazul tablourilor neregulate bidimensionale: 
Tip[][] nume; 


Intantiere: 


nume = new Tip[Liniil,I[l; 


nume [0l=new Tip[Coloanel] 


nume [Linii-1]=new Tip[Coloanerinii-11 
Acces: 
nume [indicel] [indice2] 
Exemple: 
int[][] mat = new int[][] { 

new int[3] {1,2,3}, 

new int[2] {4,5}, 

new int [4] {7,8,9,1} 

}; Sau 

int[][] mat={new int[3] {1,2,3},new int[2] {4,5},new int[4] {7,8,9,1}}; 


Siruri de caractere 


Se definesc douä tipuri de siruri: 
° regulate 
° de tip verbatim” 
Tipul regulat contine intre ghilimele zero sau mai multe caractere, inclusiv secvente escape. 
Secventele escape permit reprezentarea caracterelor care nu au reprezentare grafica 
precum si reprezentarea unor caractere speciale: backslash, caracterul apostrof, etc. 


Secventá Efect 
escape 
V apostrof 
V ghilimele 
N backslash 
V0 null 
Va alarmá 
\b backspace 
\f form feed — pagina noua 
\n new line — linie noua 
\r carriage return — inceput de ränd 
\t horizontal tab — tab orizontal 
vu caracter unicode 
W vertical tab — tab vertical 
\x caracter hexazecimal 
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Ín cazul in care folosim multe secvente escape, putem utiliza sirurile verbatim. Aceste siruri 
pot sa contina orice fel de caractere, inclusiv caracterul EOLN. Ele se folosesc in special in 
cazul in care dorim sä facem referiri la fisiere si la registri. Un astfel de sir incepe 
întotdeauna cu simbolul’@’ înaintea ghilimelelor de început. 


Exemplu: 


using System; 


namespace SiruriDeCaractere 


{ 


class Program 


{ 


static void Main(string[] 


{ 
string a 
string b 
string c 
linia doi"; 


string d= 


string e 


Console.WriteLine (a); 
Console.WriteLine (c); 
Console.WriteLine (e); 


args) 


= "un sir de caractere"; 
= "linia unu \nlinia doi"; 
= @"linia unu 


"c:\\exemple\\unu.cs"; 

= @"c:\exemple\unu.cs"; 
Console.Writeline (b); 
Console.WriteLine (d); 
Console.ReadLine(); 


) 
) 


Programul va avea iesirea 


un sir de caractere 
linia unu 

linia doi 

linia unu 

linia doi 
c:NexempleNunu.cs 
c:NexempleNunu.cs 


3.7. Conversii 


Conversii numerice 


În C£ există două tipuri de conversii numerice: 


e implicite 
° explicite. 


Conversia implicită se efectuează (automat) doar dacă nu este afectată valoarea 
convertită. Regulile de conversie implicită sunt descrise de tabelul următor: 


din în 
sbyte short, int, long, float, double, decimal 
byte short, ushort, int, uint, long, ulong, float, double, decimal 
short int, long, float, double, decimal 
ushort int, uint, long, ulong, float, double, decimal 
int long, float, double, decimal 
uint long, ulong, float, double, decimal 
long float, double, decimal 
char ushort, int, uint, long, ulong, float, double, decimal 
float double 
ulong float, double, decimal 


Conversia explicită se realizează prin intermediul unei expresii cast, atunci când nu 
există posibilitatea unei conversii implicite. 


Exemplu: 


int i=Console.Read(); 


c-char (i); 


char c; 
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Conversii boxing si unboxing 


Datoritá faptului ca in C# toate tipurile sunt derivate din clasa Object 
(System.Object), prin conversiile boxing (impachetare) si unboxing (despachetare) este 
permisá tratarea tipurilor valoare drept obiecte si reciproc. Prin conversia boxing a unui tip 
valoare, care se pástreazá pe stivá, se produce ambalarea in interiorul unei instante de tip 
referintá, care se pástrazá in memoria heap, la clasa Object. Unboxing permite convertirea 
unui obiect intr-un tipul valoare corespunzátor. 


Exemplu: 


Prin boxing variabila i este asignata unui obiect ob: 
int i = 13; 


object ob = (object)i;  //boxing explicit 

sau 

int i = 13; 

object ob = i; //boxing implicit 

Prin conversia de tip unboxing, obiectul ob poate fi asignat variabilei intregi i: 
int i=13; 

object ob = i; //boxing implicit 

i = (int)ob; //unboxing explicit 


3.8. Constante 


In C# existá douá modalitáti de declarare a constantelor: folosind const sau folosind 
modificatorul readonly. Constantele declarate cu const trebuie sa fie initializate la 
declararea lor. 


Exemple: 

const int x; //gresit, constanta nu a fost initializata 
const int x = 13; //corect 

3.9. Variabile 


O variabilá in C# poate sá continä fie o valoare a unui tip elementar, fie o referintä la 
un obiect. 


Exemple: 

int Salut; 

int Azi_si maine; 
char caracter; 


3.10. Expresii si operatori 


Prin expresie se intelege o secventä formatä din operatori si operanzi. Un operator 
este un simbol ce indicá actiunea care se efectueazá, iar operandul este valoarea asupra 
cáreia se executä operatia. 

În C# sunt definiti mai multi operatori. În cazul în care într-o expresie nu intervin 
paranteze, operaţiile se execută conform prioritätii operatorilor. În cazul în care sunt mai 
multi operatori cu aceeaşi prioritate, evaluarea expresiei se realizează de la stânga la 
dreapta. 


Prioritate Tip Operatori Asociativi-tate 
0 Primar () [] fü. x++ x-- new typeof sizeof 
checked unchecked -> > 
1 Unar +- |! ~ ++x --x (tip) true false & sizeof > 
2 Multiplicativ * 1% > 
3 Aditiv +- — 
4 De deplasare << >> — 
5 Relational < > <= >= is as zy 
6 De egalitate == != — 


Limbajul C# 23 


7 AND (SI) logic | & — 

8 XOR (SAU | ^ — 
exclusiv) logic 

9 OR (SAU) logic | | — 

10 AND (SI) | && — 
conditional 

11 OR (SAU) | || — 
conditional 

12 Conditional ?: = 

13 De atribuire ie &= <<= >>= |= — 


3.11. Colecţii 


O colecţie în C# este o clasă specializată pentru memorarea şi regăsirea rapidă a 
informaţiilor. Ea implementează metode specifice de actualizare dinamică colecţiei, de 
căutare şi de enumerare a datelor. Cel mai des folosite sunt colecţiile de obiecte şi colecțiile 
generice (vezi capitolul 5.1) cum ar fi liste, stive, hash-uri. Aceste clase pot fi derivate pentru 
a obţine colecţii specializate care se potrivesc cel mai bine necesităților de memorare a 
datelor specifice unei aplicaţii. Colecţiile sunt definite în spațiul System.Collection. Metodele 
uzuale ale claselor din spaţiul Collection sunt: Add, Remove, IndexOf, Sort, Reverse, 
CopyToArray, Find, Foreach etc. 


3.12. Instructunea foreach 


Cum instrucţiunile de apel, atribuire, decizie, selecţie şi trei structuri repetitive coincid 
ca formă şi funcţionalitate cu cele din C, ne oprim sumar numai unora dintre noile structuri de 
control specifice limbajului CF. 

Instrucţiunea foreach enumeră elementele dintr-o colecţie sau dintr-un tablou, 
executând un bloc de instrucţiuni pentru fiecare element al colecţiei sau tabloului. La fiecare 
iteratie, elementul curent al colecției este de tip readonly, neputând fi modificat. Amintim că 
în instrucţiunea repetitivă foreach se pot utiliza cu exact aceeaşi funcţionalitate 
instrucțiunile de salt break şi continue. 

instrucțiunea se utilizează curent în aplicaţii pentru tablouri şi colecţii de obiecte”. 

Pentru a vedea cum acţionează o vom compara cu instrucţiunea cunoscută for. Fie 
vectorul nume format din şiruri de caractere: 
string[] nume={“Ana”, Ionel”, Maria”); 

Să afişam acest şir folosind instrucţiunea for: 
for (int i=0; i«nume.Length; i++) 

{ 
Console.Write("(0) ", nume[il); 


Acelasi rezultat il obtinem folosind instructiunea foreach: 
foreach (string copil in nume) 
{ 
Console.Write(“{0} ", copil); 


3.13. Instructiunile try-catch-finally si throw 


Prin exceptie se intelege un obiect care incapsuleaza informatii despre situatii 
anormale in functionarea unui program. Ea se foloseste pentru a semnala contextul in care 


8 de exemplu, pentru prelucrarea sistematicá a tuturor componentlelor unei ferestre (butoane, 
liste, casete de text etc.) 


24 POO si Programare vizualá (suport de curs) 


apare o situatie specialá. De exemplu: erori la deschiderea unor fisiere, impàrtire la O etc. 
Aceste erori se pot manipula astfel incát programul sá nu se termine abrupt. 

Sunt situatii in care prefigurám aparitia unei erori intr-o secventä de prelucrare si atunci 
integrám secventa respectivá in blocul unei instructiuni try, precizänd una sau mai multe 
secvențe de program pentru tratarea exceptiilor apărute (blocuri catch) şi eventual o 
secvență comună care se execută după terminarea normală sau după "recuperarea" 
programului din starea de excepţie (blocul fina11y). 


Exemplu: 
using System; 
using System.IO; 
class tryCatch 
{ 
static void Main(string[] args) 
{ string s; 
Console.Write ("Numele fisierului:"); 
Console.Readln(s); 
try 
{ 


File.OpenRead(s); 
) 
catch (FileNotFoundException a) 
{ 
Console.WriteLine (a.ToString ()); 
} 
catch (PathTooLongException b) 
{ 
Console.WriteLine (b.ToString ()); 
} 
finally 
{ 
Console.WriteLine ("Programul s-a sfarsit"); 
Console.ReadLine(); 


Alteori putem simula prin program o stare de eroare “aruncând” o excepţie 
(instructiunea throw) sau putem profita de mecanismul de tratare a erorilor pentru a 
implementa un sistem de validare a datelor prin generarea unei exceptii proprii pe care, de 
asemenea, o "aruncam” in momentul neindeplinirii unor conditii puse asupra datelor. 

Clasa System.Exception si derivate ale acesteia servesc la tratarea adecvată si 
diversificată a excepțiilor. 


Exemplu: Considerăm clasele Copil, Fetita, Baiat definite fragmentat în capitolul 1. O 
posibilitate de validare la adăugara unui copil este aceea care generează o excepţie proprie 
la depăşirea dimensiunii vectorului static copii: 

public static void adaug copil(Copil c) 
{ 
if (nr_copii < nr_max) 
copii[nr_copiit+] = c; 
else throw new Exception("Prea multi copii"); 
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4. Programare vizualá 
4.1. Concepte de bazá ale programárii vizuale 


Programarea vizualä trebuie privitä ca un mod de proiectare a unui program prin 
operare directá asupra unui set de elemente grafice (de aici vine denumirea de programare 
vizualá). Aceastá operare are ca efect scrierea automatá a unor secvente de program, 
secvențe care, împreună cu secvențele scrise textual”, vor forma programul. 

Spunem că o aplicație este vizuală dacă dispune de o interfaţă grafică sugestivă şi 
pune la dispoziţia utilizatorului instrumente specifice de utilizare (drag, click, hint etc.) 

Realizarea unei aplicaţii vizuale nu constă doar în desenare şi aranjare de controale, ci 
presupune în principal stabilirea unor decizii arhitecturale“, decizii ce au la bază unul dintre 
modelele arhitecturale de bază: 


a) Modelul arhitectural orientat pe date. 
Acest model nu este orientat pe obiecte, timpul de dezvoltare al unei astfel de aplicaţii 
este foarte mic, o parte a codului este generată automat de Visual Stdio.Net, codul nu 
este foarte uşor de întreţinut şi este recomandat pentru aplicaţii relativ mici sau cu multe 
operaţii de acces (in/out) la o bază de date. 

b) Modelul arhitectural Model-view-controller 
Este caracterizat de cele trei concepte de bază : Model (reprezentarea datelor se 
realizează într-o manieră specifica aplicaţiei: contine obiectele de business”, 
încapsulează accesul la date), View (sunt utilizate elemente de interfață, este format 
din Form-uri), Controller( procesează şi răspunde la evenimente iar SO, clasele Form 
şi Control din .Net rutează evenimentul către un „handler”, eveniment tratat în codul din 
spatele Form-urilor). 


c) Modelul arhitectural Multi-nivel 
Nivelul de prezentare ( interfața) 
Se ocupă numai de afişarea informaţiilor către 


Window utilizator si captarea celor introduse de acesta. Nu 
UI Code cuprinde detalii despre logica aplicatiei, si cu atát 


= mai mult despre baza de date sau fisierele pe 
ll care aceasta le utilizeazá. Cu alte cuvinte, in 
` 


Presentation Tier 


cadrul interfetei cu utilizatorul, nu se vor folosi 
obiecte de tipuri definite de programator, ci numai 
Business Tier baza din .NET. 


Nivelul de logicá a aplicatiei 


Se ocupá de tot ceea ce este specific aplicatiei 
I care se dezvolta. Aici se efectueaza calculele si 


procesarile si se lucreaza cu obiecte de tipuri 
definite de programator. 


: T === Nivelul de acces la date 
ata Services Object Data Services Ohject aa I " 
(Optional) (Optional) Aici rezidá codul care se ocupá cu accesul la 


TET rz ëm r= P === baza de date, la fisiere, la alte servicii. 


Data Tier 


Aceastä ultimä structurá este foarte buná pentru a organiza aplicatiile, dar nu este usor 
de realizat. De exemplu, dacá in interfata cu utilizatorul prezentám date sub formä ListView 
si la un moment dat clientul ne cere reprezentarea datelor intr-un GridView, modificárile la 
nivel de cod nu se pot localiza doar in interfatä deoarece cele douä controale au nevoie de 
modele de acces la date total diferite. 


29 Se utilizeazá ades antonimia dintre vizual (operatii asupra unor componente grafice) si textual 
(scriere de linii de cod); proiectarea oricárei aplicatii "vizuale" imbiná ambele tehnici. 
Deciziile arhitecturale stabilesc in principal cum se leagá interfata de restul aplicatiei si cát de 
usor de intretinut este codul rezultat. 
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Indiferent de modelul arhitectural ales, in realizarea aplicatiei mai trebuie respectate si 
principiile proiectárii interfetelor: 
e Simplitatea 
Interfața trebuie să fie cát mai uşor de înțeles“! si de învățat de către utilizator şi să permită 
acestuia să efectueze operaţiile dorite în timp cât mai scurt. În acest sens, este vitală 
culegerea de informaţii despre utilizatorii finali ai aplicaţiei şi a modului în care aceştia sunt 
obişnuiţi să lucreze. 


e Poziţia controalelor 
Locaţia controalelor dintr-o fereastră trebuie să reflecte importanţa relativă şi frecvenţa de 
utilizare. Astfel, când un utilizator trebuie să introducă nişte informaţii — unele obligatorii şi 
altele opţionale — este indicat să organizăm controalele astfel încât primele să fie cele care 
preiau informații obligatorii. 

e Consistenta 
Ferestrele şi controalele trebuie să fie afişate după un design asemănător („template”) pe 
parcursul utilizării aplicaţiei. Înainte de a implementa interfața, trebuie decidem cum va arăta 
aceasta, să definim ,template"-ul. 


e Estetica 
Intefata trebuie sa fie pe cat posibil placuta si atragatoare. 


4.2. Mediul de dezvoltare Visual C# 


Mediul de dezvoltare Microsoft Visual C# dispune de instrumente specializate de 
proiectare, ceea ce permite crearea aplicatiilor in mod interactiv, rapid si usor. 

Pentru a construi o aplicatie Windows (File>New Project) se selecteaza ca template 
Windows Application. 

O aplicatie Windows contine cel putin o fereastra (Form) in care se poate crea o 
interfata cu utilizatorul aplicatiei. 

Componentele vizuale ale aplicatiei pot fi prelucrate in modul Designer (Shift+F7) 
pentru a plasa noi obiecte, a le stabili proprietăţile etc. Codul "din spatele” unei componente 
vizuale este accesibil in modul Code (F7). 

In fereastra Solution Explorer sunt afisate 
toate fisierele pe care Visual Studio.NET le-a inclus 
in proiect. Form1.cs este formularul creat implicit de 
Visual Studio.NET ca parte a proiectului. 

Fereastra Properties este utilizata pentru a 
vizualiza si eventual schimba proprietatile obiectelor. 


Toolbox wo x| 
+ All Windows Forms | 
+ Common Controls 
+ Containers 

| Menus & Toolbars 


xoaoo | Nd | 


+ 


+ Data 
Toolbox contine controale standard drag- + Components 
and-drop si componente utilizate in crearea aplicatiei + Printing 
Windows. Controalele sunt grupate in categoriile + Dialogs 
= General 


logice din imaginea alaturata. 
Designer, Code, Solution Explorer si celelalte se afla grupate in meniul View. 


La crearea unei noi aplicatii vizuale, Visual Studio.NET genereaza un spatiu de nume 
ce contine clasa statica Program, cu metoda statica ce constituie punctul de intrare (de 
lansare) a aplicatiei: 

static void Main() 
{ 


Application.Run(new Forml()); 
} 
Clasa Application este responsabila cu administrarea unei aplicatii Windows, punänd la 
dispozitie proprietáti pentru a obtine informatii despre aplicatie, metode de lucru cu aplicatia 
si altele. Toate metodele si proprietátile clasei Application sunt statice. Metoda Run invocatä 


31 Întrucât mintea umană poate să perceapă la un moment dat aproximativ 5-9 obiecte, o 
fereastră supra-încărcată de controale o face greu de utilizat. 
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mai sus creeazá un formular implicit, aplicatia ráspunzánd la mesajele utilizatorului pana 
cänd formularul va fi inchis. 

Compilarea modulelor aplicaţiei si asamblarea lor într-un singur fişier "executabil" se 
realizează cu ajutorul opţiunilor din meniul Build, uzuală fiind Build Solution (F6). 

Odată implementată, aplicaţia poate fi lansată, cu asistență de depanare sau nu 
(opțiunile Start din meniul Debug). Alte facilități de depanare pot fi folosite prin umărirea pas 
cu pas, urmărirea până la puncte de întrerupere etc. (celelalte opţiuni ale meniului Debug). 
Ferestre auxiliare de urmărire sunt vizualizate automat în timpul procesului de depanare, sau 
pot fi activate din submeniul Windows al meniului Debug. 


4.3. Ferestre 


Spaţiul Forms ne oferă clase specializate pentru: creare de ferestre sau formulare 
(System.Windows.Forms.Form), elemente specifice (controale) cum ar fi butoane 
(System.Windows.Forms.Button), casete de text (System.Windows.Forms.TextBox) etc. 
Proiectarea unei ferestre are la bază un cod complex, generat automat pe măsură ce noi 
desemnăm componentele şi comportamentul acesteia. În fapt, acest cod realizează: 
derivarea unei clase proprii din System.Windows.Forms.Form, clasă care este înzestrată 
cu o colecţie de controale (iniţial vidă). Constructorul ferestrei realizază instantieri ale 
claselor Button, MenuStrip, Timer etc. (orice plasám noi în fereastră) şi adaugă referintele 
acestor obiecte la colecţia de controale ale ferestrei. 

Dacă modelul de fereastră reprezintă ferestra principală a aplicaţiei, atunci ea este 
instantiata automat în programul principal (metoda Main). Dacă nu, trebuie să scriem noi 
codul ce realizează instantierea. 


Clasele derivate din Form moştenesc o serie de proprietăți care determină atributele 
vizuale ale ferestrei (stilul marginilor, culoare de fundal, etc.), metode care implementează 
anumite comportamente (Show, Hide, Focus etc.) şi o serie de metode specifice (handlere) 
de tratare a evenimentelor (Load, Click etc.). 


O fereastră poate fi activată cu form.Show() sau cu form.ShowDialog(), metoda a 
doua permiţând ca revenirea în fereastra din care a fost activat noul formular să se facă 
numai după ce noul formular a fost inchis (spunem că formularul nou este deschis modal). 


Un propietar este o fereastră care contribuie la comportarea formularului deţinut. 
Activarea propietarului unui formular deschis modal va determina activarea formularului 
deschis modal. Când un nou formular este activat folosind form.Show() nu va avea nici un 
deținător, acesta stabilindu-se direct : 
public Form Owner ( get; set; ) 

F nou form-new F nou(); 
form.Owner = this; form.Show(); 

Formularul deschis modal va avea un proprietar setat pe null. Detinätorul se poate 
stabili setánd proprietarul înainte sa  apelám Form.ShowDialog() sau apelând 
From.ShowDialog() cu proprietarul ca argument. 

F nou form = new F nou();form.ShowDialog (this); 

Vizibilitatea unui formular poate fi setatä folosind metodele Hide sau Show. Pentru a 
ascunde un formular putem folosi : 
this.Hide(); // setarea propietatii Visible indirect sau 
this.Visible = false; // setarea propietatii Visible direct 


Printre cele mai uzuale proprietäti ale form-urilor, reamintim: 

e  StartPosition determina poziţia ferestrei atunci când aceasta apare prima data, poziție 
ce poate fi setată Manual sau poate fi centrată pe desktop (CenterScreen), stabilită de 
Windows, formularul având dimensiunile si locaţia stabilite de programator 
(WindowsDefaultLocation) sau Windows-ul va stabili dimensiunea iniţială şi locaţia 
pentru formular (WindowsDefaultBounds) sau, centrat pe formularul care l-a afişat 
(CenterParent) atunci când formularul va fi afişat modal. 


28 POO si Programare vizualá (suport de curs) 


Location (X,Y) reprezintá coordonatele coltului din stánga sus al formularului relativ la 
colțul stânga sus al containerului. (Această propietate e ignorată daca StartPosition = 
Manual). 
Mişcarea formularului ( şi implicit schimbarea locației) poate fi tratată în evenimentele 
Move şi LocationChanged . 
Locaţia formularului poate fi stabilită relativ la desktop astfel: 

void Form Load(object sender, EventArgs e) { 

this.Location = new Point(1, 1); 

this.DesktopLocation = new Point(1, 1); ) //formularul in desktop 


Size (Width si Height) reprezintá dimensiunea ferestrei. Cänd se schimbä propietätile 
Width si Height ale unui formular, acesta se va redimensiona automat, aceastä 
redimensionare fiind tratatä in evenimentele Resize sau in SizeChanged. 
Chiar dacá propietatea Size a formularului indicá dimensiunea ferestrei, formularul nu este 
in totalitate responsabil pentru desenarea intregului continut al sáu. Partea care este 
desenatä de formular mai este denumitä si Client Area. Marginile, titlul si scrollbar-ul sunt 
desenate de Windows. 
MaxinumSize si MinimumSize sunt utilizate pentru a restrictiona dimensiunile unui 
formular. 

void Form Load(object sender, EventArgs e) { 

this.MinimumSize = new Size(200, 100);... 

this.MaximumSize = new Size(int.MaxValue, 100);...) 
IsMdiContainer precizeazá dacá form-ul reprezintá un container pentru alte form-uri. 
ControlBox precizeazä dacá fereastra contine sau nu un icon, butonul de inchidere al 
ferestrei şi meniul System (Restore, Move, Size, Maximize,Minimize,Close). 


HelpButton-precizeazá dacá butonul €! va apárea sau nu längä butonul de inchidere al 
formularului (doar dacá MaximizeBox=false, MinimizeBox=false). Dacá utilizatorul apasá 
acest buton si apoi apasá oriunde pe formular va apárea evenimentul HelpRequested 
(F1). 

Icon reprezintä un obiect de tip *.ico folosit ca icon pentru formular. 

MaximizeBox si MinimizeBox precizeazá dacá fereastra are sau nu butonul Maximize si 
respectiv Minimize 

Opacity indică procentul de opacitate?? 

ShowlnTaskbar precizeaza daca fereastra apare in TaskBar atunci cand formularul este 
minimizat. 


SizeGripStyle specifica tipul pentru ‘Size Grip’ (Auto, Show, Hide). Size grip A în colțul 
din dreapta jos) indică faptul că această fereastră poate fi redimensionată. 

TopMost precizează dacă fereastra este afisată în fata tuturor celorlalte ferestre. 
TransparencyKey identifică o culoare care va deveni transparentă pe formă. 


Definirea unei functii de tratare a unui eveniment asociat controlului se realizează prin 


selectarea grupului Events din ferestra Properties a controlului respectiv şi alegerea 


evenimentului dorit. 


Dacă nu scriem nici un nume pentru funcţia de tratare, ci efectuăm dublu click în 
căsuţa respectivă, se generează automat un nume pentru această funcţie, ţinând cont de 
numele controlului şi de numele evenimentului (de exemplu putton1 Click). 

Dacă în Designer efectuăm dublu click pe un control, se va genera automat o funcție 
de tratare pentru evenimentul implicit asociat controlului (pentru un buton evenimentul 
implicit este Click, pentru TextBox este TextChanged, pentru un formular Load etc.). 


Printre evenimentele cele mai des utilizate, se numără : 
e Load apare când formularul este pentru prima data încărcat în memorie. 


32 Dacă va fi setată la 10% formularul şi toate controalele sale vor fi aproape invizibile. 
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FormClosed apare cänd formularul este inchis. 

e FormClosing apare cand formularul se va inchide ca rezultat al acţiunii utilizatorului 
asupra butonului Close (Dacă se setează CancelEventArgs.Cancel =True atunci se 
va opri închiderea formularului). 

e Activated apare pentru formularul activ. 

Deactivate apare atunci când utilizatorul va da click pe alt formular al aplicatiei. 


4.4. Controale 


Unitatea de bază a unei interfețe Windows o reprezintă un control. Acesta poate fi 
»gazduit” de un container ce poate fi un formular sau un alt control. 

Un control este o instanţă a unei clase derivate din System.Windows.Forms şi este 
reponsabil cu desenarea unei parti din container. Visual Studio .NET vine cu o serie de 
controale standard, disponibile în Toolbox. Aceste controale pot fi grupate astfel: 


e Controale de actiune (de exemplu button) care, atunci când sunt acţionate, se poate 
executa o prelucrare. De exemplu, cel mai important eveniment pentru Button este Click 
(desemnând acţiunea click stânga pe buton). 


În exemplul PV1 se adaugă pe formular două butoane şi o casetă 5 
text. Apasarea primului buton va determina afisarea textului din TextBox 
intr-un MessageBox iar apásarea celui de-al doilea buton va inchide 
inchide aplicatia. Dupá adáugarea celor douá butoane si a casetei text a 
fost schimbat textul afisat pe cele douá butoane au fost scrise functiile 
de tratare a evenimentului Click pentru cele douá butoane: 


Inchide apheatio 


private void buttonl_Click (object sender, System.EventArgs e) 
{ MessageBox.Show (textBox1.Text); } 

private void button2_Click (object sender, System.EventArgs e) 
{ Forml.ActiveForm.Dispose();] 


e Controale valoare (label, textbox, picturebox) care arată utilizatorului o informatie 
(text, imagine). 

Label este folosit pentru plasarea de text pe un formular. Textul afisat este continut in 
propietatea Text si este aliniat conform propietatii TextAlign. 
TextBox - permite utilizatorului sa introduca un text. Prevede, prin intermediul 
ContextMenu-ului asociat, un set de functionalitati de baza, ca de exemplu (Cut, 
Copy, Paste, Delete, SelectAll). 
PictureBox permite afisarea unei imagini. 


Exemplul PV2 afiseaza un grup alcatuit din 3 
butoane, etichetate A,B respectiv C avänd initial 
culoarea rosie. Apasarea unui buton determina 
schimbarea culorii acestuia in galben. La o noua 
apásare butonul revine la culoare initialá. Actionarea 
butonului “Starea butoanelor” determină afişarea într-o WW 
casetä text a etichetelor butoanelor galbene. Caseta 
text devine vizibilä atunci cánd apásám prima oará 
acest buton. Culoarea butonului mare (verde/portocaliu) 
se schimba atunci cand mouse-ul este pozitionat pe 
buton. 


Afiseaza starea butoanelor 


Afiseaza starea butoanelor 


Ges 


După adăugarea butoanelor şi a casetei text pe | M] |E 
formular, stabilim evenimentele care determină 
schimbarea culoriilor şi completarea casetei text. 
private void buttonl Click(object sender, System.EventArgs e) 
{if (buttonl.BackColor== Color.IndianRed) buttonl.BackColor=Color.Yellow; 
else buttonl.BackColor= Color.IndianRed; } 
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private void button4_MouseEnter(object sender, System.EventArgs e) 
{button4.BackColor=Color.YellowGreen;button4.Text="Butoane apasate";] 
private void button4 MouseLeave(object sender, System.EventArgs e) 
{textBox1.Visible=false;button4.Text="Starea butoanelor"; 
button4.BackColor=Color.Orange; } 
private void button4_Click (object sender, System.EventArgs e) 
{textBox1.Visible=true;textBox1.Text=""; 
if( buttonl1.BackColor==Color.Yellow)textBox1.Text=textBox1.Text+'A'; 
if( button2.BackColor==Color.Yellow)textBox1.Text=textBox1.Text+'B'; 
if( button3.BackColor==Color.Yellow) textBox1.Text=textBox1.Text+'C'; 
} 


Exercitiu Modificati aplicatia precedentä astfel incät sa avem un singur eveniment 
button Click, diferentierea fiind fácutá de parametrul sender. 

Exercitiu ( Password) Adáugati pe un formular o casetä text in care sà introduceti un 
sir de caractere si apoi verificati daca acesta coincide cu o parolä data. Textul introdus in 
casetä nu este vizibil (fiecare caracter este inlocuit cu*). Rezultatul va fi afigat intr-un 
MessageBox. 


e Controale de selecție (CheckBox,RadioButton) au propietatea Checked care indica 
daca am selectat controlul. Dupa schimbarea stárii unui astfel de control, se declanseazä 
evenimentul Checked. Daca propietatea ThreeState este setata, atunci se schimba 
functionalitatea acestor controale, in sensul cá acestea vor permite setarea unei alte 
stări. In acest caz, trebuie verificată propietatea CheckState(Checked, 
Unchecked,Indeterminate) pentru a vedea starea controlului. 


Aplicația PV3 este un exemplu de utilizare a mm 
acestor controale. Soluţia unei probleme cu 
mai multe variante de răspuns este memorată | !erelareSmeresitituie sapu 

cu ajutorul unor checkbox-uri cu proprietatea |: 72 ©: EEE, 

ThreeState. Apäsarea butonului Verificä Veica | ` Sunttisiauz e 

determină afişarea unei etichete si a 

butoanelor radio DA şi NU. Răspunsul este afişat într-un MessageBox. 

După adăugarea controalelor pe formular şi setarea proprietăţilor Text şi ThreeState în 

cazul checkbox-urilor stabilim evenimentele click pentru butonul Verifica şi pentru butonul 

radio cu eticheta DA: 

private void radioButtonl Click (object sender, System.EventArgs e) 

(if (checkBoxl.CheckState--CheckState.Checked && 
checkBox2.CheckState--CheckState.Checked && 
checkBox3.CheckState--CheckState.Checked && 
checkBox5.CheckState==CheckState.Checked && 
checkBox4.CheckState==CheckState.Unchecked) MessageBox. Show ("CORECT"); 

else MessageBox.Show("Indicatie» Daca punem un sac in altul...."); 

label2.Visible-false; 

radioButtonl.Checked-false; radioButton2.Checked-false; 

radioButtonl.Visible=false; radioButton2.Visible=false; } 

private void buttonl_Click (object sender, System.EventArgs e) 

{label2.Visible=true; radioButton1.Visible=true; radioButton2.Visible=true; } 


Exercitiu (Test grilă) Construiti un test grilă care contine 5 itemi cu cate 4 variante de 
ráspuns (alegere simpla sau multipla), memorati ráspunsurile date si afisati, dupa efectuarea 
testului, intr-o casetá text, in dreptul fiecárui item, ráspunsul corect. 


e  LinkLabel afişează un text cu posibilitatea ca anumite parti ale textului (LinkArea) sa fie 
desenate ca si hyperlink-uri. Pentru a face link-ul functional trebuie tratat evenimentul 
LinkClicked. 


În exemplul PV4, prima etichetă permite afişarea conținutului discului C:, a doua legătură 
este un link către pagina www.microsoft.com/romania şi a treia accesează Notepad. 
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Click pentru a explora C 
Click pentru a naviga www.microsoft.corm/romania 


Click pentru a rula Notepad 


Address (& http://www. microsoft, com/romania} 


E Untitled - No... EI 


File Edit Format View Help Romänia 
See Microsoft 


Produse 
private void etichetaC LinkClicked (object sender, 
LinkLabelLinkClickedEventArgs e ) 


( etichetaC.LinkVisited = true; 
System.Diagnostics.Process.Start( @"C:\" );} 
private void etichetal_LinkClicked( object sender, 
LinkLabelLinkClickedEventArgs e ) 
{etichetal.LinkVisited = true; 
System.Diagnostics.Process.Start ("IExplore", 
"http://www.microsoft.com/romania/" );} 
private void etichetaN_LinkClicked( object sender, 
LinkLabelLinkClickedEventArgs e ) 
{etichetaN.LinkVisited = true; 
System.Diagnostics.Process.Start( "notepad" );} 


Exercitiu (Memorator) Construiti o aplicatie care sà continá patru legáturi cätre cele 
patru fisiere/ pagini care contin rezumatul capitolelor studiate. 


e Controale pentru listare (ListBox, CheckedListBox, ComboBox, ImageList) ce pot fi 
legate de un DataSet, de un ArrayList sau de orice tablou (orice sursá de date ce 
implementeazá interfata IEnumerable). 


În exemplul PV5 elementele selectate din 
CheckedListBox se adaugă în ListBox. După 


adăugarea pe formular a CheckedListBox-ului, Lai 

stabilim colecția de itemi — (Properties-Items- | |¥ Met 

Collection), butonul Selectie si ListBox-ul. Z Joi 
Evenimentul Click asociat butonului Setectie goleste SE 


mai întâi listBox-ul (listBox1.Items.Clear();) si | "EN 

dupá aceea adaugá in ordine fiecare element Am selectat si am adaugat itemii: Marti Joi Duminica 
selectat din CheckedListBox. Suplimentar se afiseazä 

o etichetá cu itemii selectati. 


void buttonl_Click (object source, System.EventArgs e) 
( String s = "Am selectat si am adaugat itemii: "; 
listBox1.Items.Clear(); 
foreach ( object c in checkedListBox1.CheckedItems) 
{listBoxl.Items.Add(c) ; 
s = s + c.ToString();s = s + " ";} 
labell.Text = s;} 


Exercitiu ( Filtru) Construiti o aplicaţie care afişează fişierele dintr-un folder ales care 
au un anumit tip ( tipul fisierelor este ales de utilizator 
pe baza unui CheckedListBox) 


Aplicatia PV6 este un exemplu de utilizare a DUALES 2 ig 


controlului ImageList. Apásarea butonului Desene va 
adăuga fişierele * gif din folderul C:Mmagini în lista si va 
afisa continutul acesteia. Butonul Animate va determina 
afisarea fisierelor *.gif cu ajutorul PictureBox. 
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ImageList desene animate = new System.Windows.Forms.ImageList (); 
private void contruieste lista Click(object sender, System.EventArgs e) 
(// Configureaza lista 
desene animate.ColorDepth -System.Windows.Forms.ColorDepth.Depth8Bit; 
desene animate.ImageSize = new System.Drawing.Size(60, 60); 
desene animate.Images.Clear(); 
string[] gif uri = Directory.GetFiles("C:\\Imagini", "*.gif"); 
// se construieste un obiect Imagine pentru fiecare fisier si se adauga la ImageList. 


foreach (string fisier gif in gif uri) 
(Bitmap desen- new Bitmap (fisier gif); 
desene animate.Images.Add(desen);pictureBox2.Image-desen;] 


Graphics g = this.CreateGraphics(); 
// Deseneaza fiecare imagine utilizand metoda  ImageList.Draw() 
for (int i = 0; i < desene animate.Images.Count; i++) 
desene animate.Draw(g, 60 + i * 60, 60, i); 
g.Dispose(); 
} 


Exercitiu (Thumbnails) Afisati intr-o ferestrá continutul folder-ului curent in mod View- 
Thumbnails. 


e MonthCalendar afişează un calendar prin care se poate selecta o data (zi, luna, an) în 
mod grafic. Proprietatile mai importante sunt: MinDate, MaxDate, TodayDate ce 
reprezintă data minima/maxima selectabilá si data curentă (care apare afişată diferentiat 
sau nu în funcţie de valorile proprietăţilor ShowToday,ShowTodayCircle. Există 2 
evenimente pe care controlul le expune: DateSelected si DateChanged. In rutinele de 
tratare a acestor evenimente, programatorul are acces la un obiect de tipul 
DateRangeEventArgs care contine proprietátile Start si End (reprezentánd intervalul de 
timp selectat). 


Formularul din aplicatia PV7 contine un 
calendar pentru care putem selecta un interval de 


maximum 30 de zile, sunt afişate săptămânile si En a RI E 


8/29/2007 


Sun Mon Tue Wed Thu Fr Sat 


ziua curentá. Intervalul selectat se afigeazá prin als sro sun 


33/12 13 14 15 16 


intermediul unei etichete. Daca se selectează o aj aa 2 2 
dată atunci aceasta va fi adăugată ca item într-un Today: 8711/2007 
ComboBox (orice dată poate apărea cel mult o 


dată în listă). 


După adăugarea celor 3 controale pe formular, stabilim proprietăţile pentru 
monthCalendar1 (ShowWeekNumber-True, MaxSelectionCount-30, etc.) şi precizám ce 
se executä atunci cánd selectäm un interval de timp: 

private void monthCalendarl_DateSelected (object sender, 

System.Windows.Forms.DateRangeEventArgs e) 


( this.labell.Text = "Interval selectat: Start = " 
te.Start.ToShortDateString() + " : End =" 
+ e.End.ToShortDateString(); 

if (e.Start.ToShortDateString()--e.End.ToShortDateString()) 


(String x=e.Start.ToShortDateString(); 
if(!(comboBoxl.Items.Contains (x) ) ) 
comboBox1.Items.Add(e.End.ToShortDateString());) 
) 


e DateTimePicker este un control care (ca si MonthCalendar) se poate utiliza pentru a 
selecta o datá. La click se afigeazá un control de tip MonthCalendar, prin care se poate 
selecta data doritá. Fiind foarte asemänätor cu MonthCalendar, proprietätile prin care se 
poate modifica comportamentul controlului sunt identice cu cele ale controlului 
MonthControl. 
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Exercitiu (Formular) Contruiti un formular de introducere a datelor necesare realizàrii 
unei adrese de e-mail. Data nasterii va fi selectatä direct utilizand MonthCalendar. 


e ListView este folosit pentru a afisa o colectie de elemente in unul din cele 4 moduri 

(Text, Textrlmagini mici, Imagini mari, Detalii). Acesta este similar grafic cu 
ferestrele in care se afiseazä fisierele dintr-un anumit director din Windows Explorer. 
Fiind un control complex, contine foarte multe proprietáti, printre care: 
View ( selectează modul de afişare (Largelcon, Smalllcon, Details, List)), 
LargelmageList, SmalllmageList (icon-urile de afisat in modurile Largelcon, 
Smalllcon), Columns(utilizat doar în modul Details, pentru a defini coloanele de 
afişat), Items(elementele de afişat). 


Aplicația PV8 este un exemplu de utilizare 
ListVie W. Se porneste d e la ràdàci n à Si se C:\WINDOWS (Apasati Doublu Click pe folder) 


afişează conţinutul folder-ului selectat cu dublu | “Z — A 
click. La expandare se afigeazá numele complet, ju Nie 
data ultimei accesári si, in cazul fisierelor, wen 22 Lee 
dimensiunea. wes TA? 043 
Controlul lista fisiere este de tip ListView. Bice ear 
Funcţia ConstruiesteHeader permite || «= 8712200 42580 


stabilirea celor trei coloane de afisat. 


private void ConstruiesteHeader () 
{ColumnHeader colHead;colHead = new ColumnHeader(); 


colHead.Text - "Nume fisier"; 

this.lista fisiere.Columns.Add(colHead); 

colHead = new ColumnHeader();colHead.Text = "Dimensiune"; 
his.lista fisiere.Columns.Add(colHead); 

colHead = new ColumnHeader();colHead.Text = "Ultima accesare"; 


this.lista fisiere.Columns.Add(colHead); 
} 
Pentru item-ul selectat se afiseazä mai intäi folderele si dupä aceea fisierele. Pentru aceasta 
trebuie sà determinám continutul acestuia: 
ListViewItem lvi; 
ListViewItem.ListViewSubItem lvsi; 


this.calea curenta.Text = radacina + "(Doublu Click pe folder)"; 
System.IO.DirectoryInfo dir = new System.IO.DirectoryInfo (radacina); 
DirectoryInfo[] dirs = dir.GetDirectories(); 


FileInfo[] files = dir.GetFiles(); 
sá stergem vechiul continut al listei: 
this.lista fisiere.Items.Clear(); 
this.lista fisiere.BeginUpdate(); 
si sa adáugám fiecare nou item ( coloana a doua este vida in cazul foldere-lor): 
foreach (System.IO.DirectoryInfo fi in dirs) 
{ lvi = new ListViewItem();lvi.Text = fi.Name; 
lvi.ImageIndex = 1; lvi.Tag = fi.FullName; 
lvsi = new ListViewItem.ListViewSubItem(); 
lvsi.Text = "";lvi.SubItems.Add(lvsi); 
lvsi = new ListViewItem.ListViewSubItem(); 
lvsi.Text = fi.LastAccessTime.ToString(); 
lvi.SubItems.Add(lvsi); this.lista fisiere.Items.Add(lvi); 
} 


Exercitiu (Ordonare) Modificati aplicatia anterioarä astfel incat apásarea pe numele 
unei coloane sa determine afisarea informatiilor ordonate dupa criteriul specificat (nume, 
dimensiune, data). 


e Controale "de control” al executării (Timer) sau de dialog (OpenFileDialog, 
SaveFileDialog, ColorDialog, FontDialog, ContextMenu). 
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e Grupuri de controale Toolbar (ToolStrip) afiseaza o bara de butoane in partea de sus a 
unui formular. Se pot introduce vizual butoane (printr-un designer, direct din Visual 
Studio.NET IDE), la care se pot seta atát textul afisat sau imaginea. Evenimentul cel mai 
util al acestui control este ButtonClick (care are ca parametru un obiect de tip 
ToolBarButtonClickEventArgs, prin care programatorul are acces la butonul care a fost 
apasat). 


Ín aplicatia urmátoare PV9 cele 3 butoane ale 
toolbar-ului permit modificarea proprietăților textului 
introdus în casetă. Toolbar-ul se poate muta fără a depăşi 
spațiul ferestrei. Schimbarea fontului se realizează cu 
ajutorul unui control FontDialog(),iar schimbarea culorii 
utilizează ColorDialog() 


FontDialog fd = new FontDialog(); 
fd.ShowColor = true;fd.Color = Color.IndianRed; 
fd.ShowApply = true; 
fd.Apply += new EventHandler (ApplyFont); 
if(fd.ShowDialog() !- 
System.Windows.Forms.DialogResult.Cancel) 
{ this.richTextBox1.Font= fd.Font; 
this.richTextBox1.ForeColor=fd.Color; 
} 
ColorDialog cd = new ColorDialog(); 
cd.AllowFullOpen = true;cd.Color = Color.DarkBlue; 
if(cd.ShowDialog() == System.Windows.Forms.DialogResult.OK) 
this.richTextBox1.ForeColor = cd.Color; 


Mutarea toolbar-ul este dirijată de evenimentele produse atunci când apăsăm butonul de 
mouse şi/sau ne deplasăm pe suprafaţa ferestrei. 


private void toolBarl_MouseDown (object sender, MouseEventArgs e) 
( // am apasat butonul de mouse pe toolbar 
am apasat = true; 
forma deplasata = new Point (e.X, e.Y); toolBarl.Capture = true;) 
private void toolBarl_MouseUp (object sender, MouseEventArgs e) 
( am apasat = false;toolBarl.Capture = false;] 
private void toolBarl_MouseMove (object sender, MouseEventArgs e) 
( if (am apasat) 


Text nou Font | Culoare 


ToolBar mutat !| 


ToolBar-ul se misca II 


{ if(toolBarl.Dock == DockStyle.Top | | toolBarl.Dock == DockStyle.Left) 
{ // daca depaseste atunci duc in stanga sus 
if (forma deplasata.X < (e.X-20) || forma deplasata.Y < (e.Y-20)) 
( am apasat = false;// Disconect toolbar 


toolBarl.Dock = DockStyle.None; 
toolBarl.Location = new Point (10, 10); 
toolBarl.Size = new Size(200, 45); 
toolBarl.BorderStyle = BorderStyle.FixedSingle; 


} 
} 
else if (toolBarl.Dock == DockStyle.None) 
(toolBarl.Left = e.X + toolBarl.Left - forma deplasata.X; 
toolBarl.Top = e.Y + toolBarl.Top - forma deplasata.Y; 
if (toolBarl.Top < 5 || toolBarl.Top>this.Size.Height-20) 
{ am apasat = false;toolBarl.Dock = DockStyle.Top; 
toolBarl.BorderStyle = BorderStyle.Fixed3D; } 
else if (toolBarl.Left < 5 || toolBarl.Left > this.Size.Width - 20) 
{ am_apasat = false;toolBarl.Dock = DockStyle.Left; 
toolBarl.BorderStyle = BorderStyle.Fixed3D; 
}}} 


Exercitiu (Editor) Realizati un editor de texte care contina un control toolBar cu butoanele 
uzuale. 
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e Controale container (GroupBox, Panel, TabControl) sunt controale ce pot contine alte 
controale. 


Aplicația PV10 simulează lansarea unei Dow 
comenzi către un magazin de jucării. Se utilizează 4 
pagini de Tab pentru a simula selectarea unor opțiuni 


ce se pot grupa pe categorii. 


Categorie Culoare Varsta copilului| Contact 


Nume: Bogdan 


Prenume Rares 


Exercitiu (Magazin) Dezvoltati aplicația Adresa str.Pacli nr.3 Bucuresti 
precedentä astfel incat pe o pagina sa se afiseze 
modelele disponibile (imagine+detalii) şi sa se 
permitä selectarea mai multor obiecte. Ultima pagina ple e epu aina 


va fi trimisa pe adresa Bogdan Bogdan str.Pacii nr.3 Bucuresti 


reprezintá cosul de cumpáráturi. 


e Grupuri de controale tip Meniu (MenuStrip, ContextMenuStrip etc.) 

Un formular poate afişa un singur meniu principal la un moment dat, meniul asociat 
initial fiind specificat prin propietatea Form.MainMenusStrip. Meniul care este afişat de către 
un formular poate fi schimbat dinamic la rulare : 

switch (cond) { case condl:this.MainMenuStrip this.mainMenul;break; 

case cond2:this.MainMenuStrip = this.mainMenu2; 
) 
unde mainMenu1 şi mainMenu2 sunt obiecte de tip MenuStrip. Editarea unui astfel de 
obiect se poate face utilizând Menu Designer. Clasa MenuStrip are o colecţie de Menultem 
care conţine 0 sau mai multe obiecte de tip Menultem. Fiecare dintre aceste obiecte de tip 
Menultem are 0 sau mai multe obiecte de tip Menultem, care vor constitui noul nivel de itemi 
(Ex: File 2New,Save, Open, Close, Exit). 

Propietátile Checked si RadioCheck indică itemul selectat, Enabled and Visible 
determină dacă un item poate fi sau nu selectat sau vizibil, Shortcut permite asignarea unei 
combinaţii de taste pentru selectarea unui item al meniului şi Text memorează textul care va 
fi afişat pentru respectivul item al meniului. 

Evenimentul Click are loc când un utilizator apasă un item al meniului. 


Exemplul PV11 permite, prin 
intermediul unui meniu, scrierea unui fisier 
Notpad, afişarea continutului acestuia într- 
o casetă text, schimbarea fontului şi culorii 
de afişare, ştergerea conţinutului casetei, 
afişarea unor informații teoretice precum şi 
Help dinamic. Au fost definite chei de 
acces rapid pentru accesarea 
componentelor meniului. 

File New permite scrierea unui fişier notepad nou 
System.Diagnostics.Process.Start( "notepad" ); 

File? Open selectează şi afişează în caseta text conţinutul unui fişier text. 
OpenFileDialog of = new OpenFileDialog(); 


of.Filter = "Text Files (*.txt)|*.txt"; 

of.Title = "Fisiere Text"; 

if (of.ShowDialog() == DialogResult.Cancel)return; 
richTextBox1.Text="";richTextBox1.Visible=true; 


FileStream strm; 

try{strm = new FileStream (of.FileName, FileMode.Open, FileAccess.Read); 
StreamReader rdr = new StreamReader (strm); 
while (rdr.Peek() >= 0) {string str = rdr.ReadLine (); 

richTextBox1.Text=richTextBox1.Text+" "+str;} 

} 

catch (Exception) {MessageBox.Show ("Error opening file", "File Error", 

MessageBoxButtons.OK, MessageBoxIcon.Exclamation);) 


File> Close şterge conținutul casetei text, File Exit închide aplicaţia 
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Window > Font si Window Color permit stabilirea fontului/culorii textului afisat. 

Help DinamicHelp accesează System.Diagnostics.Process.Start ("IExplore", 
"http://msdn2.microsoft.com/en-us/default.aspx"); 

Help> About PV afiseazä in caseta text informatii despre implementarea unui menu. 


Exercitiu (Fisiere) Contruiti un menu care sä permitä efectuarea operatiilor uzuale cu fisiere. 
4.5. System.Drawing 


Spatiul System.Drawing COntine tipuri care permit realizarea unor desene 2D si au 
rol deosebit in proiectarea interfetelor grafice. 

Un obiect de tip Point este reprezentat prin coordonatele unui punct intr-un spatiul 
bidimensional (exemplu: Point myPoint = new Point(1,2);) 

Point este utilizat frecvent nu numai pentru desene, ci si pentru a identifica in program 
un punct dintr-un anumit spatiu. De exemplu, pentru a modifica pozitia unui buton in 
fereastrá putem asigna un obiect de tip Point proprietätii Location indicánd astfel pozitia 
coltului din stánga-sus al butonului (button.Location = new Point(100, 30)). Putem 
construi un obiect de tip Point pentru a redimensiona un alt obiect. 

Size mySize - new Size(15, 100); 
Point myPoint - new Point (mySize); 
System.Console.WriteLine("X: " + myPoint.X + ", Y: " + myPoint.Y); 


Structura coior contine date, tipuri si metode utile in lucrul cu culori. Fiind un tip 
valoare (struct) si nu o clasá, aceasta contine date si metode, insá nu permite instantiere, 
constructori, destructor, mostenire. 

Color myColor = Color.Brown; buttonl.BackColor = myColor; 


Substructura FromArgb a structurii Color returnează o culoare pe baza celor trei 
componente ale oricărei culori (red, green, blue). 


Clasa Graphics este o clasă sigilată reprezentând o arie rectangulară care permite 
reprezentări grafice. De exemplu, o linie frântă se poate realiza astfel: 
Point[] points = new Point[4]; 
points[0] = new Point (0, 0);points[1] = new Point (0, 120); 
points[2] = new Point (20, 120) ;points[3] = new Point (20, 0); 
Graphics g = this.CreateGraphics(); 
Pen pen = new Pen (Color.Yellow, 2); 
g.DrawLines (pen, points); 


Aplicatia PV12 este un exercitiu care deseneaza cercuri de raze si 
culori aleatoare si emite sunete cu frecventä aleatoare. 


Random x = new Random(); 
Console.Beep (300 + x.Next (1000), 150); 
Graphics g = e.Graphics; 

i = 1 + x.Next (30); 

p=new Pen (System.Drawing.Color.FromArgb (x.Next (256) ,x.Next (256),x.Next (256))) 
g.DrawEllipse(p, x.Next (100), x.Next (100), i, i); 
Console.Sleep (200); EE Pv13 DOS 


In exemplul PV13 se construieste o pictogramá pe baza unei imagini. 


Image thumbnail; 
private void Thumbnails Load(object sender, EventArgs e) 
{ try(Image img = Image.FromFile ("C:\\Imagini\\catel.jpg"); 
int latime-100, inaltime-100; 
thumbnail-img.GetThumbnaillmage (latime, inaltime,null, 
IntPtr.Zero) ; } 
catch{MessageBox.Show("Nu exista fisierul");] 

} 

private void Thumbnails_Paint (object sender, PaintEventArgs e) 
(e.Graphics.DrawImage (thumbnail, 10, 10);} 
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4.6. Validarea informatiilor de la utilizator 


Inainte ca informatiile de la utilizator sa fie preluate si transmise catre alte clase, este 
necesar sa fie validate. Acest aspect este important, pentru a preveni posibilele erori. Astfel, 
daca utilizatorul introduce o valoare reala (float) cand aplicatia asteaptä un intreg (int), este 
posibil ca aceasta sà se comporte neprevázut abia cáteva secunde mai tarziu, si dupa multe 
apeluri de metode, fiind foarte greu de identificat cauza primará a problemei. 


Validarea la nivel de càmp 

Datele pot fi validate pe másurá ce sunt introduse, asociind o prelucrare unuia dintre 
handlerele asociate evenimentelor la nivel de control (Leave, Textchanged, MouseUp etc.) 
private void textBox1 KeyUp(object sender, 

System.Windows.Forms.KeeyEventArgs e) 

(if(e.Alt--true) MessageBox.Show ("Tasta Alt e apasata"); // sau 
if (Char.IsDigit (e.KeyChar)==true) MessageBox.Show("Ati apasat o cifra"); 
} 


Validarea la nivel de utilizator 

În unele situaţii (de exemplu atunci când valorile introduse trebuie să se afle într-o 
anumită relaţie între ele), validarea se face la sfârşitul introducerii tuturor datelor la nivelul 
unui buton final sau la închiderea ferestrei de date. 
private void btnValidate Click (object sender, System.EventArgs e) 
{ foreach (System.Windows.Forms.Control a in this.Controls) 

{ if( a is System.Windows.Forms.TextBox & a.Text=="") 
{ a.Focus();return; } 


} 


ErrorProvider 
O maniera simpla de a semnala erori de validare este aceea de a seta un mesaj de 
eroare pentru fiecare control . 


myErrorProvider.SetError(txtName," Numele nu are spatii in stanga"); 


Aplicatii recapitulative. 

Urmăriţi aplicaţiile si precizati pentru fiecare dintre ele controalele utilizate, 
evenimentele tratate: Forma poloneza (PV14), Triunghi (PV15), Ordonare vector(PV16), 
Subsir crescător de lungime maximă(PV17), Jocul de Nim (PV18) 


Exercitiu (Test grila) Realizati un generator de teste grilă (întrebările sunt preluate 
dintr-un fisier text, pentru fiecare item se precizează punctajul, enunţul, răspunsul corect, 
distractorii şi o imagine asociată enuntului (dacă există). După efectuarea testului se 
afişează rezultatul obţinut si statistica răspunsurilor. 
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5. Aplicatii orientate pe date 
5.1. Structuri de date 


Construirea unei aplicatii ce gestioneazá un volum mare de date necesitá o atentie 
particulará privind organizarea acestor date. Sursele de date trebuie si ele integrate 
corespunzátor intr-o aplicatie OOP. Faptul cà o stivá din clasa Stack este implementatá ca 
vector sau nu, este de mica importantä pentru programatorul pe platforma NET. Dar pentru 
operaţiile executate de o aplicaţie ce monitorizează traficul dintr-o gară de triaj, este 
important de ştiut dacă trebuie memorat sau nu un istoric al acestor operaţii, dacă sunt 
folosite informaţiile de acest tip în prelucrări ulterioare sau sunt doar listate sub formă de 
rapoarte periodice, etc. Dacă datele trebuie exportate către alte aplicaţii, atunci se pune 
problema formatului în care vor fi salvate. Pentru colecţiile consistente de date care suferă 
prelucrări ample şi frecvente se pune problema suportului de memorare astfel încât să 
suporte tehnici de acces rapide etc. 


5.2. Colecţii de date 


Colecţia, în general, reprezintă un ansamblu bine structurat de componente de acelaşi 
tip, ansamblu ce permite identificarea rapidă a oricărei componente din colecție. Definiţia 
este aplicabilă şi colecţiilor de date. Uneori, cloectiile de date sunt percepute ca date externe 
(aflate pe harddisc sau alte suporturi de memorare), dar asta nu exclude posibilitatea 
organizării datelor interne sub forma unor colecţii. În C#, colecţiile sunt clase specializate 
aparținând spaţiului System.Collection. Despre colecţii am mai vorbit în cadrul capitolului 3.11. 
Aducem unele completări în cele ce urmează vorbind despre structuri generice de date. 

Atributul "generic" se referă la proprietatea de a referi o întreagă categorie de obiecte. 
Clasele, structurile, metodele, interfețele, delegații şi metodele pot fi generice, adică pot fi 
concepute astfel încât să depindă de unul sau mai multe tipuri de date pe care acestea le 
memorează sau manipulează. 

De exemplu, la declararea unei clase obişnuite, noi stabilim elementele fixe ale 
acesteia: numele şi tipurile datelor, numele metodelor“ şi altor componente ce formează 
clasa respectivă. Pentru o funcţie (metodă) obişnuită sunt definite atât numele, cât şi tipul 
parametrilor funcţiei”. 

C# introduce, începând de la versiunea 2.0, parametrizarea tipurilor, adică posibilitatea 
declarării unor clase, metode etc. în care tipul datelor manevrate nu este cunoscut decât la 
apel. Acest tip de date constituie un parametru al clasei, metodei etc. 

Vom defini în mod obişnuit şi, paralel, în mod generic clasa Stiva (amintită şi în 
capitolul 1.1) pentru a pune în evidenţă diferenţele induse de modul de lucru ... generic: 


class Stiva class Stiva<T> 
{ { 
int[] st = new int [10]; int vf; T[] st = new T[10]; int vf; 
public Stiva() ( vf = -1; } public Stiva() ( vf = -1; ) 
public void Push(int x) public void Push(T x) 
{ st[++vf] = x; ) { st[++vf] = x; ) 
public int Pop() public T Pop()*° 
{ return st[vf--]; }” ( return st[vf--]; ) 
public void scrie() public void scrie() 
{for (int i = 0; i <= vf; i++) {for (int i = 0; i <= vf; i++) 
Console.Write (st [i]); Console.Write (st [i]); 
Console.WriteLine(); Console.WriteLine(); 


) ) 
) ) 


33 A nu se confunda capacitatea de a defini mai multe metode cu acelasi nume cu faptul cà 
numele este bine determinat. A spune cà numele nu este definit ar presupune un fel de declarare cu 
numele ... si abia la apel sà se stabileascá ce nume este scris in loc de ... @ 

"7 Numărul parametrilor este si el bine definit, deşi funcţiile care au definit un parametru de tip 
tablou, permit apelul cu un numár variabil de parametri efectivi. 

? Versiuni mai vechi de C nu executá conform asteptárilor returul valorii cu postincrementare. 
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static void Main(string[] args) 

{ 

Stiva s = new Stiva(); 
s.Push (7) ;s.Push (5); s.scrie(); 
Console.WriteLine („Ex{0},s.Pop()); 
s.scrie(); 

s.Push(7); s.scrie(); 
Console.WriteLine ("Ex{0}",s.Pop()); 
s.scrie(); 


) 


static void Main(string[] args) 

{ 

Stiva<int> s = new Stiva<int>() 
s.Push (7); s.Push (5); s.scrie() 
Console.WriteLine ("Ex{0}",s.Pop 
s.scrie(); 

s.Push(7); s.scrie(); 
Console.WriteLine ("Ex{0}",s.Pop()); 
s.scrie(); 


) 


( 


)); 


Dintre clasele generice "predefinite", cele mai des utilizate sunt colectiile generice. 
Astfel, clasele si interfetele din spatiul System.Collection.Generic permit organizarea 
datelor proprii, indiferent de tipul acestora, in structuri specifice cum ar fi: liste (List), liste 
dublu inläntuite (LinkedList), stive (Stack), cozi (Queue), dictionare (Dictionary) etc. 

De exemplu, dorim sá gestionám un ansamblu de ferestre asemánátoare, instantiate 
dintr-o aceeasi clasá MyForm (sà zicem) derivata din System.Windows.Forms.Form. 
Putem memora in program sau ca element static al clasei MyForm o structurá de tip listä: 

List<MyForm> fer-new List<MyForm> () 

La crearea oricärei ferestre f de tipul MyForm (MyForm f=new MyForm(); f.Show();) 
se adaugă referinţa ferestrei in lista fer (fer.Add(f)). Analog, la închiderea ferestrei, se va 
elimina referința acesteia din lista (fer. Remove (f) ). 

Exercitiu: Presupunem cá implementäm o aplicatie in care se completeazá datele 
unui pacient într-o fereastră. Pentru a nu încărca ferestra curentă, aceasta este proiectată sa 
conţină butoane ce permit deschiderea unor ferestre secundare pentru completarea unor 
subcategorii de date (istoricul suferințelor cronice, analize efectuate, adresa detaliată etc.). 
De exemplu, în fereastră se completează numele pacientului, iar apoi, apăsând pe butonul 
Adresa, se deschide o fereastră ce permite completarea câmpurilor ce formează adresa, la 
închiderea ferestrei revenind la fereastra principală. Desigur, şi o fereastră secundară poate 
avea la rândul ei butoane pentru alte ferestre secundare în raport cu aceasta. Stabiliti ce tip 
de Structură generică se poate utiliza pentru gestiunea ferestrelor deschise la un moment 
dat”. 


5.3. ADO.NET 


ADO.NET (ActiveX Data Objects) reprezintă o parte componentă a nucleului NET 
Framework ce permite accesarea si manipularea datelor. Amintim ca o sursä de date poate 
fi: un fisier text, un fisier Excel sau XML, o bazä de date Dbase, Access, SQL etc. Lucrul cu o 
sursa de date se poate face fie conectat, fie deconectat de la sursa de date. ADO.NET 
implementeazä clase ce oferä servicii atät pentru lucrul in stil deconectat cät si conectat, 
oferä instrumentele de utilizare si reprezentare XML, de combinare a datelor din diferite 
surse si de diferite tipuri (pe bazá mecanismenlor de reprezentare comunä implementate de 
NET. Maniera de lucru deconectată recomandă metoda ca fiind mai eficientă în proiectarea 
aplicaţiilor pentru Internet decât alte tehnologii cum ar fi ADO sau ODBC. 

Deoarece există mai multe tipuri de baze de date e nevoie de câte o bibliotecă 
specializată de clase şi interfeţe care să implementeze un "protocol" specific pentru fiecare. 


5.4. Conectarea la o sursă de date 


Înainte de orice operaţie cu o sursă de date externă, trebuie realizată o conexiune 
(legătură) cu acea sursă. Clasele din categoria Connection (SQLConnection, 
OleDbConnection etc.) contin date referitoare la sursa de date (locaţia, numele si parola 
contului de acces, etc.), metode pentru deschiderea/închiderea conexiunii, pornirea unei 
tranzacţii etc. Aceste clase se găsesc în subspatii (Sq/Client, OleDb etc.) ale spațiului 
System.Data. În plus, ele implementează interfața /DbConnection. 


36 punem accentul pe faptul că ferestrele sunt modale 
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Pentru deschiderea unei conexiuni prin program se poate instantia un obiect de tip 
conexiune, precizándu-i ca parametru un sir de caractere continánd date despre conexiune. 
Dàm douá exemple de conectare la o sursá de date SQL respectiv Access: 
using System.Data.SqlClient; 


SqlConnection co = new SqlConnection(8"Data Source-serverBD; 
Database-scoala;User ID=elev;Password=madonna"); 
co.Open (); 


using System.Data.OleDb; 


OleDbConnection con = 
new OleDbConnection (@"Provider=Microsoft.Jet.OLEDB.4.0; 
Data Source=C:\Date\scoala.mdb"); 
en.Open (); 


Proprietätile unei conexiuni 

ConnectionString (String): contine un string cu o succesiune de parametri de forma 

parametru=valoare, despärtiti prin ;. Parametrii pot fi: 

e provider. specificä furnizorul de date pentru conectarea la sursa de date. Acest furnizor 
trebuie precizat doar dacá se foloseste OLE DB .NET Data Provider, si nu se specificà 
pentru conectare la SQL Server 

e Data Source: se specifica numele serverului de baze de date sau numele fisierului de date 

e Initial Catalog (Database): specifica numele bazei de date. Baza de date trebuie sa se 
gáseascá pe serverul dat in Data Source. 

User ID: specifica un nume de cont de utilizator care are acces de logare la server. 

e Password: specificá parola contului de mai sus. 

ConnectionTimeout (int): specificá numärul de secunde pentru care un obiect de 
conexiune poate sà astepre pentru realizarea conectärii la server inainte de a se genera o 
excepție. (implicit 15). Se poate specifica o valoare diferită de 15 in ConnectionString 
folosind parametrul Connect Timeout, Valoarea Timeout=0 specifica asteptare nelimitatà. 
SqlConnection cn = new SqlConnection ("Data Source-serverBD; 
Database-scoala;User ID=elev;Password=madonna; Connect Timeout=30"); 
Database (string): returneazá numele bazei de date la care s-a fácut conectarea. Este 
necesará pentru a aráta unui utilizator care este baza de date pe care se face operarea 
Provider (string): returneazá furnizorul 
ServerVersion (string): returneazá versiunea de server la care s-a fäcut conectarea. 

State (enumerare de componente ConnectionState): returneazá starea curentá a conexiunii. 

Valorile posibile: Broken, Closed, Connecting, Executing, Fetching, Open. 


Metodele unei conexiuni 
Open () : deschide o conexiune la baza de date 
Close () Si Dispose () : închid conexiunea şi eliberează toate resursele alocate pentru ea 
BeginTransaction(): pentru executarea unei tranzacţii pe baza de date; la sfârşit se 
apelează Commit () sau Rollback (). 
ChangeDatabase (): se modifică baza de date la care se vor face conexiunile. Noua bază 
de date trebuie să existe pe acelaşi server ca şi precedenta. 
CreateCommand (): creează o comandă (un obiect de tip Command) validă asociată 
conexiunii curente. 


Evenimentele unei conexiuni 
StateChange: apare atunci când se schimbă starea conexiunii. Handlerul corespunzător (de 
tipul delegat StateChangeEventHandler) spune între ce stări s-a făcut tranziţia. 
InfoMessage: apare când furnizorul trimite un avertisment sau un mesaj către client. 
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5.5. Executarea unei comenzi SQL 


Clasele din categoria Command (SQLCommand, OleDbCommand etc.) contin date 
referitoare la o comandá SQL (SELECT, INSERT, DELETE, UPDATE) si metode pentru 
executarea unei comenzi sau a unor proceduri stocate. Aceste clase implementeazá 
interfata /DbCommand. Ca urmare a interogárii unei baze de date se obtin obiecte din 
categoriile DataReader sau DataSet. O comandă se poate executa numai după ce s-a 
stabilit o conxiune cu baza de date corespunzătoare. 

SqlConnection co = new SqlConnection(8"Data Source=serverBD; 
Database-scoala;User ID=elev;Password=madonna"); 

co.Open (); 

SqlCommand cmd = new SqlCommand ("SELECT * FROM ELEVI", con); 


Proprietátile unei comenzi 
CommandText (String): contine comanda SQL sau numele procedurii stocate care se 
executá pe sursa de date. 
CommandTimeout (int): reprezintä numárul de secunde care trebuie sà fie asteptat pentru 
executarea comenzii. Dacá se depáseste acest timp, atunci se genereazá o exceptie. 
CommandType (enumerare de componente de tip CommandType): reprezintä tipul de 
comandä care se executä pe sursa de date. Valorile pot fi: StoredProcedure (apel de 
procedurá stocatä), Text (comandä SQL obisnuitä), TableDirect (numai pentru OleDb) 
Connection (System. Data. [Provider].PrefixConnection): contine obiectul de tip conexiune 
folosit pentru legarea la sursa de date. 
Parameters (System.Data.[Provider].PrefixParameterCollection): returneazá o colectie de 
parametri care s-au transmis comenzii; 
Transaction (System.Data.[Provider].PrefixTransaction): permite accesul la obiectul de tip 
tranzactie care se cere a fi executat pe sursa de date. 


Metodele unei comenzi 

Constructori: Sq1Command () sau SqlCommand (string CommandText) sau 

SqlCommand (string CommandText, SqlConnection con ) sau 
SqlCommand (string CommandText,SqlConnection con, SqlTransaction trans) 
Cancel () opreste o comandá aflatä in executare. 
Dispose () distruge obiectul comandă. 
ExecuteNonQuery () execută o comandă care nu returnează un set de date din baza de 
date; dacă comanda a fost de tip INSERT, UPDATE, DELETE, se returnează numărul de 


înregistrări afectate. 
SglCommand cmd = new SqlCommand(); 


cmd.CommandText = "DELETE FROM elevi WHERE nume = 'BARBU'"; 
cmd.Connection = con; 
Console.WriteLine (cmd.ExecuteNonQuery () . ToString ()) ; //cáte inreg.s-au şters 


ExecuteReader () executä comanda si returneazä un obiect de tip DataReader 
SqlCommand cmd = new SqlCommand("SELECT * FROM elevi",con); 
SglDataReader reader - cmd.ExecuteReader(); 
while(reader.Read()) 

{ Console.WriteLine("(0) - {1}", 
reader.GetString(0),reader.GetString(1)); 


) 


reader.Close(); 
Metoda ExecuteReader() mai are un argument optional, CommandBehavior care descrie 
rezultatele si efectul asupra bazei de date: CloseConnection (conexiunea este închisă atunci 
când obiectul DataReader este închis), KeyInfo (returneză informatie despre coloane şi cheia 
primară), SchemaOnly (returneză doar informatie despre coloane), SequentialAccess (pentru 
manevrarea valorilor binare cu GetChars() sau GetBytes()), SingleResult (se returnează un 
singur set de rezultate), SingleRow (se returnează o singură linie). 
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ExecuteScalar() executá comanda si returneazá valoarea primei coloane de pe primul 
ránd a setului de date rezultat; folosit pentru obtinerea unor rezultate statistice 
SqlCommand cmd = new SqlCommand("SELECT COUNT(*) FROM elevi",con); 
SglDataReader reader - cmd.ExecuteScalar(); 
Console.WriteLine (reader.GetString(0)); 
ExecuteXmlReader() returneazá un obiect de tipul XmlReader obtinut prin interogare 
SqlCommand CMD- 

new SqlCommand("SELECT * FROM elevi FOR XML MATE,EXAMEN", con); 
System.Xml.XmlReader myXR - CMD.ExecuteXmlReader(); 


5.6. Seturi de date 


Datele pot fi explorate in mod conectat (cu ajutorul unor obiecte din categoria 
DataReader), sau pot fi preluate de la sursä (dintr-un obiect din categoria DataAdapter) si 
inglobate in aplicatia curenta (sub forma unui obiect din categoria DataSet). 

Clasele DataReader permit parcurgerea intr-un singur sens a sursei de date, fárá 
posibilitate de modificare a datelor la sursá. Dacá se doreste modificarea datelor la sursá, se 
va utiliza ansamblul DataAdapter * DataSet. 

Un obiect DeatReader nu are constructor, ci se obtine cu ajutorul unui obiect de tip 
Command si prin apelul metodei ExecuteReader() (vezi exemplul de la pagina 41, jos). 
Evident, pe toatà durata lucrului cu un obiect de tip DataReader, conexiunea trebuie sà fie 
activă. Toate clasele DataReader (SqlDataReader, OleDbDataReader etc.) implementează 
interfața /DataReader. 

Proprietăți: 

IsClosed, HasRows, Item (indexator de câmpuri) si FieldCount 

Metode: 

Close () închidere obiectului şi eliberarea resurselor; trebuie să preceadă închiderea conxiunii 
GetBoolean(), GetByte (), GetChar(), GetDateTime (), GetDecimal(), 
GetDouble (), GetFloat(), GetInt16(), GetInt32 (), GetInt64(), GetValue(), 
GetString () returnează valoarea unui camp specificat, din inergistrarea curentă 
GetBytes (), GetChars () citirea unor octeti/caractere dintr-un câmp de date binar 
GetDataTypeName (), GetName () returnează tipul/numele câmpului specificat 

IsDBNu11 () returnează true dacă în câmpul specificat prin index este o valoare NULL 
NextResult () determină trecerea la următorul rezultat stocat în obiect (vezi exemplul) 
Read () determină trecerea la următoarea înregistrare, returnánd false numai dacă aceasta 
nu există; de reținut că iniţial poziția curentă este înaintea primei întrgistrări. 

SqlCommand cmd-new SqlCommand ("select * from elevi;select * from profi", conn ); 
conn.Open (); 

SglDataReader reader - cmd.ExecuteReader (); 


do í 
while ( reader.Read () ) 
(Console.WriteLine ( "{O}\t\t{1}", reader[0], reader[1] );) 


) while ( reader.NextResult () ); 

Folosirea combinata a obiectelor DataAdapter si DataSet permite operatii de selectare, 
stergere, modificare si adáugare la baza de date. Clasele DataAdapter genereazá obiecte 
care functioneazá ca o interfatä intre sursa de date si obiectele DataSet interne aplicatiei, 
permitänd prelucrári pe baza de date. Ele gestioneazá automat conexiunea cu baza de date 
astfel incat conexiunea sa se facá numai atunci cand este imperios necesar. 

Un obiect DataSet este de fapt un set de tabele relationate. Foloseste serviciile unui 
obiect DataAdapter pentru a-si procura datele si trimite modificárile inapoi cátre baza de date. 
Datele sunt stocate de un DataSet in format XML, acelaşi folosit si pentru transferul datelor. 

În exemplul următor se preiau datele din tablele elevi şi profi: 

SqlDataAdapter de-new SqlDataAdapter ("SELECT nume,clasa FROM elevi, conn); 
de.Fill (ds, "Elevi");//transferá datele în datasetul ds sub forma unei tabele locale numite elevi 
SqlDataAdapter dp=new SqlDataAdapter ("SELECT nume, clasdir FROM profi,conn); 

dp.Fill (ds, "Profi");//transferá datele în datasetul ds sub forma unei tabele locale numite profi 
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Proprietàtile unui DataAdapter 
DeleteCommand, InsertCommand, SelectCommand, UpdateCommand (Command), 
contin comenzile ce se executä pentru selectarea sau modificarea datelor in sursa de date. 
MissingSchemaAction (enumerare) determinä ce se face atunci cánd datele aduse nu se 
potrivesc peste schema tablei in care sunt depuse. Poate avea urmátoarele valori: 
* Add - implicit, DataAdapter adaugá coloana la schema tablei 
* AddWithKey — se aduga coloana si informatii relativ la cheia primara 
* Ignore - se ignorá lipsa coloanei respective, ceea ce duce la pierdere de date 
* Error - se genereazá o exceptie de tipul InvalidOperationException. 
Metodele unui DataAdapter 
Constructoril: SqlDataAdapter (); SAU SqlDataAdapter(obiect comanda); Sau 
SqlDataAdapter(string comanda, conexiune); 
Fill() permite umplerea unei tabele dintr-un obiect DataSet cu date. Permite specificarea 
obiectului DataSet in care se depun datele, eventual a numelui tablei din acest DataSet, 
numärul de inregistrare cu care sà se inceapa popularea (prima avänd indicele 0) si numárul 
de inregistrári care urmeazá a fi aduse. 
Update () permite transmiterea modificărilor efectuate într-un DataSet către baza de date. 
Structura unui DataSet 
Un DataSet este format din Tables (colectie formatä din obiecte de tip DataTable; DataTable 
este compus la rándul lui dintr-o colectie de DataRow si DataColumn), Relations (colectie de 
obiecte de tip DataRelation pentru memorarea legäturilor pärinte-copil) si ExtendedProperties 
ce contine proprietäti definite de utilizator. 
Scenariul uzual de lucru cu datele dintr-o tabelá contine urmátoarele etape: 
e popularea succesivă a unui DataSet prin intermediul unuia sau mai multor obiecte 
DataAdapter, apelând metoda Fill (vezi exemplul de mai sus) 
e procesarea datelor din DataSet folosind numele tabelelor stabilite la umplere, 
ds.Tables["elevi"], sau indexarea acestora, ds .Tables [0], ds. Tables[1] 
e actualizarea datelor prin obiecte comandă corespunzătoare operaţiilor INSERT, 
UPDATE şi DELETE. Un obiect CommandBuilder poate construi automat o 
combinaţie de comenzi ce reflectă modificările efectuate. 


5.7. Proiectarea vizuală a seturilor de date 


Mediul de dezvoltare Visual Studio dispune de instrumente puternice şi sugestive 
pentru utilizarea bazelor de date în aplicaţii. Conceptual, în spatele unei ferestre în care 
lucrăm cu date preluate dintr-una sau mai mlte tabele ale unei baze de date se află obiectele 
din categoriile Connection, Command, DataAdapter şi DataSet prezentate. "La vedere" se 
află controale de tip DataGridView, sau Table GridView, BindingNavigator etc. 

Meniul Data şi fereastra auxiliară Data Sources ne sunt foarte utile în lucrul cu surse de 
date externe. 

Să urmărim un scenariu de realizare a unei aplicații simple cu O | pata | Format Tools window “Cc 
fereastră în care putem vizualiza date dintr-o tabelă, putem naviga, |&] show Data Sources Shift+ält+D 


putem modifica sau şterge înregistrări. dE wanaq 
iti 3 i | Add New Data Source... 
e Initiem adăugarea unei surse de date (Add New Source) ue 
° Configurám cu atenție (asistați de vrăjitor”) conexiunea cu O ¿wass ë ro 
alee de Up Bam a Access; figura surprinde elemente de TEE a 
conectare la O bazà de date Access, numità Authors, bazà click "Change" to choose a different data source and/or 


provider, 
> 1 Data source: 
stocata pe harddiscul local. reir amen abes Fi EUR] | (change... ] 
e  Selectăm tabelele care ne interesează din baza de date şi | >= 


= š " S : : A E:\authors.mdb | 
câmpurile din cadrul tabelei ce vor fi reţinute in TableAdapter | ¿was 
(din categoria DataAdapter) Username; [admin 


Password: 


e Cand operatiunea se incheie, date relative la baza de date la 
care ne-am conectat sunt integrate in proiect si pictograma, ca 
si structura bazei de date apar in fereastra Data Source 


Save my password 


[ Test Connection ] [ OK J) | Cancel | 
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E gigel - Microsoft Visual C# 2005 Express Edition 
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1. Arhitecturi Software 
Dezvoltarea de aplicatii / programe software implica mai multe etape, programarea 

(scrierea de cod propriu-zisa) fiind doar una dintre ele si poate sá insemne doar aproximatv 
25% din timpul total de dezvoltare. Etapele sunt: 

° Analiza cerintelor 

° Proiectarea de nivel inalt (arhitectura) 

* Proiectarea componentelor 

° Implementarea 

° Testarea si validarea 

e Punerea in functiune 

° Intretinerea 


Proiectarea la nivel inalt, sau stabilirea arhitecturii are o importanta deosebita in acest 
proces, deoarece alegerile facute aici determina derularea viitoarelor etape, implicit limitele 
intre care se va programa efectiv aplicatia. Arhitectura este un model scris al unui sistem, 
care poate fi utilizat la construirea sistemului propriu-zis, şi este formata din: 

e Definirea scopului sistemului. 
e Modelul de date. 
e  Diagrame de flux de date. 
e Fluxul interfetei cu utilizatorul. 
Exista mai multe modele arhitecturale, dintre care putem aminti: 

e Modelul client-server 
e Multi-strat 

Aplicatii orientate pe servicii 


1.1. Modelul client- server 


Termenul client-server este folosit prima data in 1980, legat de calculatoarele dintr-o 
retea. Arhitectura software client-server este o infrastructurä modularä, bazatä pe mesaje. 
Un client este definit ca un solicitant de servicii, iar serverul ca un prestator de servicii. O 
masinä (un calculator) poate fi in acelasi timp atät client cät si server in functie de aplicatiile 
rulate. 

Precursoare ale modelului client-server au fost arhitecturile de tip mainframe si file 
sharing. Propozitia precedenta nu e prea corecta, pentru ca se refera strict la modul in care 
erau utilizate calculatoarele in trecut. 

Urmatoarele paragrafe nu prea au legatura cu modelul arhitectural client-server, ci tot 
cu modul in care erau utilizate calculatoarele. In plus, sunt si niste erori in exprimare, cum ar 
fi „Comunicarea intre client si server se realizeazä prin intermediul interogarilor SQL sau a 
RPC (Remote Procedure Calls)”. Una este SQL si cu totul altceva este RPC - nu prea au 
legatura. 

In arhitectura mainframe aplicatiile rulau pe un computer principal, iar utilizatorii 
interactionau cu acesta printr-un terminal (blind terminal) care trimitea informatiile tastate. 
Limitarile acestui tip de arhitecturá constau in faptul cà nu asigurau o interfatä grafica cu 
utilizatorul (GUI) si nu puteau accesa baze de date distribuite in diferite locatii. 

Retelele de calculatoare initiale se bazau pe arhitectura de tip partajare de fisiere 
(file-sharing) , in care serverul download-a fisiere (dintr-o locatie partajata) pe calculatorul 
gazda. Aici se rulau aplicatiile (datele si procesarea lor). Viteza de lucru era scazutá, iar 
numarul maxim de utilizatori, care accesa simultan resursele partajate, era mic. 

Ca urmare a limitárilor arhitecturii de tip file-sharing, a aparut modelul client — server, 
in care serverul de fisiere a fost inlocuit de un server de baze de date. Prin utilizarea unui 
sistem de gestiune a bazelor de date (SGBD) se raspundea in mod direct cererilor 
utilizatorului. De asemenea se reduce traficul in retea prin returnarea unui raspuns la o 
interogare, fata de returnarea unui intreg fisier. Apar si interfatele grafice (GUI) pentru 
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accesul la baza de date partajata (interfete numite si front-end). Comunicarea intre client si 
server se realizeazà prin intermediul interogarilor SQL sau a RPC (Remote Procedure Calls). 


= 


Server process 


Q 


Client process 


Modelul 
client- 
server 


Mecanismul RPC a aparut cu mai bine de doua decenii in urma in lumea Unix si este 
folosit in constructia de aplicatii distribuite pe sisteme eterogene, avand la baza tehnologiile 
Internet. O aplicatie RPC va consta dintr-un client si un server, serverul fiind localizat pe 
masina care executá procedura. Aplicatia client comunica prin retea — via TCP/IP — cu 
procedura de pe calculatorul aflat la distantá, transmitänd argumentele si receptionánd 
rezultatele. Clientul si serverul se executá ca douá procese separate care pot rula pe 
calculatoare diferite din retea. 

In loc de ultimele 4 paragrafe, as insista mai mult pe niste modele client-server foarte 
cunoscute, cum ar fi: 

e Windows Live Messenger. In acest caz, clientul este programul pe care il 
avem instalat pe calculatorul personal cei care dorim sá comunicam prin 
acest serviciu. Server-ul (in acest caz programul server este instalat de fapt 
mai multe masini) este programul ,central” care: 

o Are baza de date a utilizatorilor, adica a celor care au conturi de 
Windows Live. 

o Primeste mesaje de la clienti si le ,ruteaza”, adica le trimite mai 
departe catre clientul / clientii (in cazul unei conferinte) destinatari. 

o Tine evidenta sesiunilor clientilor, adica ,stie" tot timpul cand cineva 
este logged in, cu Live Messenger pornit, respectiv cand iese. 

o Etc. 

Solutiile de email, cum ar fi de exemplu serverul Exchange + Outlook. 


1.2. Modelul multi-strat 


Arhitecturile multi-strat sunt acelea in care fiecare strat logic: 
e Are un scop precis. 
e Isi vede numai de propriile responsabilitati. 
e Stie exact modul de comunicare / interactiune cu straturile adiacente. 


In astfel de arhitecturi, este usor de separat anumite functionalitati care nu ar trebui 
să depinda unele de altele. De exemplu, interfata cu utilizatorul, sau mai bine spus clasele / 
paginile care formeaza aceasta interfata, nu trebuie să ,stie” cum anume se realizeaza 
accesul la baza de date. Cu alte cuvinte, in clasele / paginile in care se afiseaza informatii, 
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nu este nevoie sà avem cod care lucreaza cu baza de date. Astfel, se realizeaza o separare 
logica benefica pentru intelegerea mai usoara si intretinerea mai eficienta a software-ului. 

De exemplu, putem avea arhitecturi multi-strat pe 2 nivele (two tier architecture), in 
care sá spunem ca interfata cu utilizatorul este situatá pe calculatorul utilizatorului sub forma 
unei aplicatii Windows (deci instalata pe calculator), iar sistemul de gestiune a bazelor de 
date pe un calculator mai puternic (server) care deserveste mai multi clienti 

O alta arhitectura pe 2 nivele poate fi o aplicatie web in care interfata propriu-zisa 
(paginile, codul de afisare a informatiilor si de captare a datelor introduse de utilizator) este 
instalata pe un server, iar baza de date pe un alt server. 

Ín arhitectura multi-strat pe 3 nivele (three tier architecture) se introduce un nou strat 
intre interfatá si SGBD. Interfata cu utilizatorul , procesarea, stocarea si accesarea datelor 
sunt module separate, care se pot situa pe platforme diferite. Acest model asigurá o 
flexibilitate sporita, fiecare modul putand fi modificat independent de celelalte. Spre exemplu 
schimbarea sistemului de operare din Windows in Linux poate afecta doar modulul de 
interfatà. 

De obicei, interfata cu utilizatorul ruleazá pe un alt calculator si foloseste o interfatà 
grafica standard (GUI), procesarea logica poate consta din unul sau mai multe module care 
ruleaza pe un server de aplicatii, iar SGBD-ul ruleaza pe un server de baze de date sau 
mainframe. Stratul de mijloc poate fi format la randul lui din mai multe nivele, caz in care 
arhitectura este numitá multi strat cu n nivele (n-tier architecture). 


Presentation tier 

The top-most level of the application is the 
user interface. The main function of the 
interface is to translate tasks and results to 
something the user can understand 


Logic tier 

This layer coordinates the application, 

processes commands, makes logical GET LIST OF ALL ADD ALL SALES 
decisions and evaluations, and performs SALES MADE TOGETHER 
calculations. It also moves and processes LAST YEAR 


data between the two surrounding layers. 


SALE 1 
avery WE 
Data tier SALE 4 
Here information is stored and retrieved 
from a database or file system. The 
information is then passed back to the logic 
tier for processing, and then eventually 
back to the user. 
—— 
— 
- 
Storage 


Cele 3 nivele sunt: 
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e Nivelul de prezentare (presentation tier) sau interfata cu utilizatorul: 
prezentarea rezultatelor sistemului catre utilizator si preluarea de informatii de 
la utilizator 

e Nivelul logic de procesare (logic tier / business logic tier/ transaction tier) : 
functionalitatea specificá aplicatiei. 

Nivelul de date (data tier): Interactiunea cu suportul datelor (baze de date, fisiere, 
servicii web, etc). 


1.3. Aplicatii orientate spre servicii 


Pentru a discuta despre Arhitecturi Orientate pe Servicii (SOA), ar trebui sá plecam 
mai intai de la definitia acestora. Din pacate nu exista o definitie universal acceptat pentru 
SOA. Ceea ce se poate spune in schimb despre acest mode este ca prin intermediul lui se 
incearca descrierea unor arhitecturi bazate pe servicii slab interconectate care suporta 
modelarea proceselor de business si a necesitatilor utilizatorilor. Resursele aflate intr-o 
„retea” sunt expuse ca servicii independente care pot fi accesate fara cunostiinte apriori 
despre ceea ce rezida in spatele lor: platforma, implementare, algoritmi, etc. 

Aceste concepte generice sunt valabile fie ca se vorbeste despre business-uri, 
software sau alte tipuri de sisteme de tip consumator-producator. 

Dupa cum mentionam anterior, arhitecturile de tip SOA nu impun utilizare unei 
anumite tehnologii [precum REST, RPC, DCOM, CORBA sau Servicii Web]. Conceptul cheie 
care permite acest lucru este faptul ca serviciile sunt independente, si pot fi apelate intr-un 
mod standardizat pentru a-si indeplini sarcinile pentru care au fost proiectate si 
implementate, fara ca serviciul sa fie nevoit sa stie in prealabil nimic despre aplicatia care il 
invoca, sau ca aplicatia care invoca serviciul sa aiba nevoie sa inteleaga mecanismele 
interne prin care serviciul isi duce la bun sfarsit rolul pentru care a fost definit. 

Putem astfel incerca sá definim SOA ca fiind: o paradigma pentru organizarea si 
utilizarea capabilitatilor distribuite care pot sá fie sub controlul unor entitati diferite. Aceasta 
paradigma ofera o modalitate uniforma de descoperire si interactioanre. 

Conceptul de baza al SOA este aceala de interconectare slaba, realizat prin 
constrangeri arhitecturale precum: 

- Fiecare serviciu ofera un set de interfete simple si care ofera doar o semantica 
generala, si care este accesibila de catre orice producator sau consumator interesat. 

- intre interfetele diferitelor servicii se schimba doar mesaje care respecta o schema 
predefinita, dar extensibila, prin intermediul carora se trimite doar continut si nu 

descriere comportamentala a sistemului. Cu alte cuvinte mesajul trebuie să aibă o 

mare putere de descriere si nu una de ,comanda”/instruire. 

Pe langa conceptul de interconectare slaba, mai exista si urmatorele concepte 
referitoare la principiile unei arhitecturi de tip SOA: 

-  Incapsularea Serviciului 

- Contractul Serviciului — se refera la faptul ca serviciile sunt de acord să comunice pe 
baza unui agreement stipulat de catre unul sau mai multe servicii prin intermediul 
unor documente descriptive 

-  Abstractizarea Serviciului — un serviciu expune ceea ce face si nu cum o face 

-  Refolosirea Serviciului — in sine conceptul se serviciu implica reutilizare. Serviciile au 
fost concepte pentru a putea să fie reutilizate. 

- Compunerea Serviciilor — colectii de servicii pot sa fie coordonate si asambalte astfel 
in cat să formeza un nou serviciu, numit un serviciu compus. 

- Autonomia Serviciului — un serviciu are control total asupra logicii pe care o 
incapsuleaza 

- Descoperirea Serviciilor — serviciile sunt concepute astfel incat sa isi descrie 
functionalitatea catre ,exterior’, astfel incat să poata fi gasite si folosite prin 
intermediul unor mecanisme de descoperire. 

Avand bazele puse pentru conceptul de SOA, in cele ce urmeaza se va incerca 
definirea Serviciilor Web pe baza acestor concepte. Serviciile Web nu sunt altceva decât o 
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modalitate prin care o arhitectura SOA este realizate, folosind un anumit set de protocoale si 
restrictii. In cazul concret al Serviciilor Web, urmatoarele doua restrictii sunt impuse: 
- Interfetele serviciilor trebuie sa fie construite peste protocoale din Internet, precum 

HTTP, FTP sau SMTP. 

- Exceptand atasamentele binare alea unor mesaje, toata comunicarea intre servicii 

trebuie sà fie fácutá prin mesaje in format XML. 

In momentul de fata exista doua mari clase de Servicii Web, si anume: SOAP si 
REST. In cele ce urmeaza vom discuta despre Servicii Web de tip SOAP si infrastructuri 
oferite de platforma NET pentru implementarea/dezvoltarea, gazduira, rularea si 
mentenanta unor Servicii Web de tip SOAP. Decizia de a descrie mai indetaliu Serviciile 
Web de tip SOAP este aceea ca ele sunt recunoscute de piata ca un standard defacto, fapt 
vizibil si prin adoptia majoritara a acestora. 

SOAP este un acronim pentru Simple Object Access Protocol. Clasa de Servicii Web 
de tip SOAP aduce urmatoarele constrangeri fata de cele mentionate mai sus: 

- Cu exceptia atasamentelor binare, toate mesajele trebuie sä fie transportate prin 
intermediul SOAP. 
- Descrierea unui Serviciu Web se va face folosind un limbaj de markup numit WSDL — 

Web Service Description Language. 

- Existenta registrelor UDDI (Universal Description Discovery and Integration) care au 
ca scop indexarea Serviciilor Web. UDDI-ul permite interogarea sá prin intermediul 

SOAP si faciliteaza accesul la WSDL-ul Serviciilor Web pe care le indexeaza. 

SOAP nu face altceva decát sá defineasca un format pentru mesaje care pot fi 
trimise intre servicii web deasupra unui numar de protocoale internet. Cu alte cuvinte, SOAP 
se comporta ca un plic care muta continut dintr-un punct in altul. 

Pentru exemplificare, mai jos este un mesaj SOAP: 

«soap:Envelope xmins:soap="http://schemas.xmlsoap.org/soap/envelope/"> 

<soap:Body> 
«obtineDetaliiCursant xmIns="http://www.example.com/WebService"> 
<IDCursant>C010030</IDCursant > 
</obtineDetaliiCursant > 
</soap:Body> 
</soap:Envelope> 


Se poate observa in exemplul de mai sus structura unui mesaj de tip SOAP: 
- Plicul: <soap:Envelope> 
- Continutul acestui delimitat de: <soap:Body> 
Odata cu dezvoltarea standardelor pentru Servicii Web de tip SOAP (de acum incolo 
numit simplu Servicii Web) si cu adoptia lor pe piata, s-a facut simtita nevoia unor standarde 
suplimentare pentru a putea exprima concepte precum securitatea, increderea si tranzactiile. 
O serie de firme din industria software au dezvoltat in consecinta o suita de standarde 
numite colectiv WS-* care trateaza aceste probleme. Telul acestor specificatii este acela de 
a oferi sabloane pentru functionalitati avansate ale Serviciilor Web, totodata pastrand 
simplitatea nativa a Serviciilor Web. Cea mai importanta trasatura a specificatiilor WS-* este 
posibilitatea lor de a fi compuse. Compunearea protocoalelor asociate acestor specificatii 
permite o dezvoltare incrementala a Serviciilor Web, pe masura ce functionalitatea lor o cere 
(securitate, incredere, atasamente, tranzactii, descoperire, etc.). Individual fiecare 
specificatie rezolva o problema izolta, dar ca un compus, ele rezolva probleme de 
functionalitate ridicata adesea intalnite in aplicatii distribuite. 
Modelul acesta poate fi exprimat schematic astfel: 
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z ; o Metadata 
Securitate Incredere Tranzacti : 


(Reliability) 


(Scheme 
XML) 


Mesaje (Comunicare bazate pe mesaje) 
XML 


In cele ce urmeaza se vor prezenta succint produsele din platforma Microsoft care 
compun ecosistemul pentru construirea si mentenanta sistemlor distribuite implementate 
folosing Servicii Web. 

Constructia de Servicii Web se poate realiza 

- folosind Microsoft Visual Studio 2005 in colaborare cu platforma NET 2.0, prin 
intermediul carora se pot implementa servicii web care sunt in conformitate cu 
standardul WS-Interoperability [WS-I]. Crearea serviciului este facila, partea de 
contract fiind generata automat pe partea serviciului, iar partea de proxy fiind 
deasemenea generata automat pe partea de client. Suportul pentru descoperire este 
deasemenea integrat prin suportarea protocolului UDDI. 

- folosind Web Service Enhancements 3.0 [WSE 3.0] in colaborare cu VS2005 si .NET 

2.0, se pot realiza Servicii Web care sunt in conformitate cu ultimele specificatii ale 

WS-*. WSE 3.0 este oferit ca un pachet care se integreaza perfect cu suita de 

dezvoltare VS 2005. WSE 3.0 aduce suport in cadrul platformei .NET 2.0 pentru 

XML, SOAP, WSDL, WS-Security, WS-Trust, WS-SecureConversation, WS- 

Addressing si MTOM 

- folosind platforma NET 3.0 care aduce un set nou de APl-uri printre care si Windows 
Communication Foundation, API care permite un model unificat de programare si 
rulare a Serviciilor Web folosind limbaje managed, precum C£. WCF aduce suport 
integral pentru toate standardele recunoscute cat si cele mai populare adoptate de 
piata, numarand astfel urmatoarele: 
o pentru trimiterea mesajelor: XML, SOAP, WS-Addressing 
o pentru descrierea interfetelor (asa numita MetaData): WSDL, WS- 
MetadataExchange, WS-Policy, WS-SecurityPolicy 
o pentru securitate: WS-Trust, WS-Security, WS-SecureConversation 
o pentru incredere: WS-ReliableMessaging 
pentru tranzactii: WS-Coordination si WS-AtomicTransactions 
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2. Protocoale de retea 
2.1. Modelul de referintá TCP/IP 


Pana in anii 60, comunicarea intre computere se realiza greoi prin intermediul liniilor 
telefonice. In 1962 Paul Baran si Donald Davies propun — independent — ideea unui sistem 
de comunicare intre retele bazat pe comutarea de pachete — packet switching. Aceastä 
arhitectura a fost implementatä de ARPANET, o retea de calculatoare sponsorizata de DoD 
(Department of Defence). Arhitectura a devenit cuoscutá mai tárziu sub denumirea de 
modelul de referintá TCP/IP, dupá numele celor douá protocoale fundamentale utilizate. 
Protocolul TCP (Transfer Control Protocol) se refera la modalitatea de transmitere a 
informatiei, iar protocolul IP (Internet Protocol) se refera la modealitatea de adresare. 

Data fiind ingrijorarea DoD ca o parte din gazde, routere si porti de interconectare ar 
putea fi distruse la un moment dat, un obiectiv major a fost ca reteaua sà poatä supravietui 
pierderii echipamentelor din subretea, fárá a intrerupe conversatiile existente. Cu alte 
cuvinte, DoD dorea ca, atäta timp cát functionau masina sursä si masina destinatie, 
conexiunile sa rámáná intacte, chiar daca o parte din masini sau din liniile de transmisie erau 
brusc scoase din functiune. Mai mult, era nevoie de o arhitecturä flexibila, deoarece se 
aveau in vedere aplicatii cu cerinte divergente, mergand de la transferul de fisiere pana la 
transmiterea vorbirii in timp real. 

Toate aceste cerinte au condus la alegerea unei retele cu comutare de pachete 
bazata pe un nivel inter-retea fara conexiuni. Acest nivel, numit nivelul internet (IP), este 
axul pe care se centreazá intreaga arhitecturä. Rolul sáu este de a permite gazdelor sa 
emitä pachete in orice retea si face ca pachetele sá circule independent páná la destinatie. 
Pachetele pot chiar sa soseascá intr-o ordine diferitä fata de cea in care au fost trimise, caz 
in care rearanjarea cade in sarcina nivelurilor de mai sus (acele nivele ce urmeaza sá 
proceseze pachetele primite). 


IL 
TCP 


Hardware Internet Hardware 
Your Computer Another Computer 
1.2.3.4 5.5.7.8 


Fiecare computer conectat la internet are o adresa de IP unicà. Adresele IP sunt sub 
forma nnn.nnn.nnn.nnn, unde nnn trebuie sa fie un numär intre 0 si 255. Spre exemplu, la 
momentul redactarii acestui document, www.microsoft.com are ip-ul 207.46.192.254. 
Fiecarui calculator îi este asociată o adresă de loopback 127.0.0.1, care înseamna “acest 
calculator”. 127.0.0.1 se mai numeşte şi localhost. În anii '80 au fost conectate la Arpanet un 
număr foarte mare de rețele. Această situație a determinat, în 1984, crearea sistemului DNS 
(Domain Name System), prin intermediul căruia calculatoarele erau organizate în domenii, 
punându-se în corespondenţă adresele IP cu numele gazdelor. 

Nivelul de transport sau TCP ataşează pachetelor trimise un număr de port al 
serviciului destinatar si directioneazá pachetele care ajung, către o anumită aplicaţie. Fiecare 
serviciu comunică pe un anumit port. Porturile sunt numere întregi care permit unui computer 
să facă diferenţa între comunicațiile internet ce au loc la un anumit moment dat. Numerele 
porturilor sunt cuprinse intre 0 si 65535 si sunt impartite in doua clase: cele pana la 1024 
sunt rezervate pentru sistemul de operare, iar cele peste 1024 sunt disponibile 
dezvoltatorilor. Prin prezenta porturilor si deoarece aplicatiile care deservesc diferite servicii 
pe un sistem ruleaza pe porturi diferite, putem avea servicii care ruleaza concomitent pe 
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acelasi calculator. Astfel, pe un sistem (server) pot rula concomitent aplicatii server si pentru 
protocolul HTTP cat si pentru protocolul FTP. Un server poate deservi clienti atat ai 
serviciului sau HTTP cat si a celui FTP, deoarece poate deosebi pachetele adresate celor 
doua servicii pe baza portului catre care sunt trimise. Cele mai comune porturi sunt: FTP : 
20/21, Telnet: 23, HTTP: 80, Microsoft SQL Server:1433. 

Printre protocoalele de nivel aplicatie, enumeram cateva din cele mai cunoscute: 
HTTP, FTP, Telnet, SMTP, SSL, POP3, IMAP, SSH etc. 

HTTP (Hyper Text Transfer Protocol) este un protocol client - server in care clientii 
(browserele web) trimit o cerere unui server web. Dupá ce serverul returneazá elementele 
cerute (imagini, text etc.) conexiunea dintre client si server este intreruptä. Acest lucru 
inseamnä cá dupá ce elementele cerute sunt descarcate pe calculatorul utilizatorului, iar 
browserul descoperá ca are nevoie de o alta resursa de pe server, se realizeazá o nouá 
cerere cátre acesta. Acest lucru inseamna cá HTTP nu este orientate pe conexiune 
(connection-oriented). 

FTP (File Transfer Protocol) faciliteazá transferul de fisiere intre douá calculatoare din 
internet. 

SMTP (Simple Mail Transfer Protocol) este un protocol folosit pentru schimbul de 
mesaje de postä electronicä. 

Telnet este un protocol care permite unui utilizator sa se conecteze de la un calculator 
la altul. 

SSL (Secure Socket Layer) este un protocol folosit pentru transmiterea de date text 
criptate in internet. 

Modelul TCP/IP este înrudit cu modelul de referință OSI (Open Systems 
Interconnection). Modelul OSI este format din 7 straturi asiguränd astfel mai multä 
flexibilitate. Acest model nu este folosit însa în practică, rămânând mai mult un model 
teoretic. In figura de mai jos se poate vedea sitva de comunicare propusa de modelul 
ISO/OSI cu cele 7 nivele ale sale. Nivelul cel mai de jos reprezinta nivelul fizic al retelei, iar 
nivelul cel mai de sus reprezinta nivelul aplicatie. In aceasta arhitectura multi-nivel, fiecare 
nivel comunica doar cu nivelele adiacente: la transmiterea de date, datele pleaca din nivelul 
aplicatiei, iar fiecare nivel comunica doar cu nivelul imediat de sub el; la primirea de date, 
fiecare nivel comunica doar cu nivelul imediat de deasupra lui. 


2.2. Protocolul HTTP 


Unul dintre cele mai importante si de succes servicii ale Internetului, World-Wide 
Web-ul — mai pe scurt Web sau spatiul WWW, a fost instituit la CERN (Centre Europeen 
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pour la Recherche Nucléaire — Centrul European de Cercetári Nucleare de la Geneva) in 
anul 1989. Web — ul a apárut din necesitatea de a permite cercetätorilor räspänditi in lume 
sà colaboreze utilizänd colectii de rapoarte, planuri, desene, fotografii si alte tipuri de 
documente aflate intr-o continuá dezvoltare. 

Comunicatia dintre clientul web (browserul) si serverul web are loc ín felul urmátor: 
procesul server Web (spre exemplu Microsoft IIS — Internet Information Services) „ascultä” 
portul TCP 80 al masinii gazde pentru a ráspunde eventualelor cereri de conexiune venite de 
la clienti. Dupá stabilirea conexiunii TCP, clientul care a initiat conexiunea trimite o cerere 
(de exemplu un document HTML), la care serverul trimite un ráspuns (documentul cerut sau 
un mesaj de eroare). Dupá trimiterea ráspunsului conexiunea dintre client si server se 
incheie. Cererile clientului si ráspunsurile serverului Web sunt descrise de protocolul HTTP 
(Hyper Text Transfer Protocol). 

Etapele care se parcurg intre cerere si ráspuns sunt: 

1. Browserul determina URL - ul cerut de utilizator. 

2. Browserul intreaba serverul local DNS adresa IP a masinii pe care se afla pagina 

cu URL-ul selectat. 
. Serverul DNS comunicá browserului adresa IP cerutä. 

4. Browserul stabileste o conexiune TCP cu portul 80 al serverului cu IP — ul obtinut 
anterior. 

Utilizänd conexiunea TCP, browserul trimite o comandä GET. 

Serverul web räspunde trimitánd un fisier HTML. 

Serverul Web inchide conexiunea TCP. 

Browserul afişează textul din fişierul HTML trimis. 

Browserul cere şi afişează şi celelalte elemente necesare în pagină (de exemplu 
imaginile). 


CANAD 


Exemplu de cerere din partea clientului: 
GET / HTTP/1.1 
Host: www.live.com 

Exemplu de raspuns al serverului: 
HTTP/1.1 200 OK 
Date: Wed, 15 Aug 2007 09:49:56 GMT 
Server: Microsoft-11S/6.0 
P3P:CP="BUS CUR CONo FIN IVDo ONL OUR PHY SAMo TELo" 
S:WEBA12 
X-Powered-By: ASP.NET 
X-AspNet-Version: 2.0.50727 
Set-Cookie: mktstate=E=8P=8B=; domain=live.com; path=/ 
Set-Cookie: mkt1=norm=-ro; domain=live.com; path=/ 
Set-Cookie: mkt2=ui=ro-ro; domain=www.live.com; path=/ 
Set-Cookie: lastMarket=ro-ro; domain=.live.com; path=/ 
Set-Cookie: lastMktPath=ro/ro; domain=.live.com; path=/ 
Set-Cookie: frm=true; domain=.live.com; expires=Mon, 
04-Oct-2021 19:00:00 GMT; path=/ 
Set-Cookie: frm=true; domain=.live.com; expires=Mon, 
04-Oct-2021 19:00:00 GMT; path=/ 
Cache-Control: no-cache 
Pragma: no-cache 
Expires: -1 
Content-Type: text/html; charset-utf-8 
Content-Length: 5939 


Metodele puse la dispozitie de protocolul HTTP sunt: 
e HEAD - clientul cere numai antetul paginii 
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GET - clientul cere serverului sá trimitä pagina specificatä 

POST - trimite date pentru a fi procesate pe server 

PUT - inlocuieste continutul paginii specificate cu datele trimise de client 
DELETE - solicitä stergerea paginii specificate 

TRACE - permite clientului sá vadá cum sunt prelucrate mesajele 

OPTIONS - returneazá metodele HTTP suportate de server 

CONNECT - converteste conexiunea de tip cerere intr-un tunel TCP/IP , de 
obicei pentru a facilita comunicatii securizate prin SSL (HTTPS). 


Formularele HTML sunt folosite pentru ca utilizatorii sa introducä date in cámpurile 
acestora si sà le transmitä serverului Web (utilizänd browserul, o conexiune TCP si 
protocolul HTTP). 

Cele mai raspandite servere Web sunt : 

e IIS (Internet Information Server) de la Microsoft. Este inclus ca parte 

componentá a sistemelor de operare Microsoft (Windows NT Server, 
Windows 2000 Server si Windows Server 2003). 

Apache (open source). Pentru a transmite date serverului se poate folosi metoda 
GET sau metoda POST. Metoda implicitä este GET. 

Dacá se utilizeazá GET, datele transmise serverului pot fi vizualizate in bara de 
adrese a browserului, ele urmánd dupá URL-ul fisierului ce contine scriptul care le va 
prelucra. Datele introduse de utilizator vor fi sub forma de perechi nume=valoare. Caracterul 
? semnifica faptul cá se transmit date cátre server, iar perechile nume=valoare pot fi 
separate prin caracterul &. De exemplu pentru a cauta informatii referitoare la ASP.NET in 
Live Search, se poate folosi url-ul: http://search.live.com/results.aspx?q-ASP.NET. 

Metoda POST permite ca transmiterea datelor către server să se facă în flux, 
putându-se transmite cantități mari de date. De asemenea, datele trimise nu mai sunt afişate 
în bara de adrese a browserului, lucru util când se transmit informaţii confidentiale. 

La nivelul serverului, datele primite de la browser (via HTTP) sunt prelucrate de un 
script, o aplicatie sau chiar un framework: 

e CGI (Common Gateway Interface). Reprezinta o serie de script-uri executate 
pe serverul web. Acestea pot fi scrise in orice limbaj de programare (interpretat sau compilat) 
cu respectarea urmatoarelor restrictii: programul scrie datele la iesirea standard si genereaza 
antete care permit serverului Web să interpreteze corect iesirea scriptului, conform 
specificatiilor HTTP. 

e PHP (iniţial Personal Home Page apoi PHP: Hypertext Preprocessor) şi ASP 
(Active Server Pages). ASP (Active Server Pages) este o platformă de programare Web 
creată de Miscrosoft. Lucrează bine cu serverul IIS, dar există versiuni si pentru alte servere 
Web. 

Desi difera din punct de vedere al sintaxei, atat PHP cat si ASP sunt interpretate, 
codul lor fiind stocat in fisiere externe cu extensia .php/.asp. De fapt, ASP nu ofera un limbaj 
nou, ci se bazeaza pe limbajele VBScript si JScript. Un fisier PHP/ASP poate fi combinat cu 
date de tip text, marcatori HTML si comenzi script. in momentul executiei, in urma cererii 
unui client Web, fisierul este procesat, fiecare script din cadrul lui este interpretat si rezultatul 
executiei este introdus inapoi in fisierul static HTML inainte ca rezultatul să fie trimis catre 
client (browser web). Aceste modele completeaza destul de bine suportul dezvoltarii 
aplicatiilor Web, insa aduc unele limitari: sunt lente deoarece la fiecare accesare fisierele 
sunt procesate si interpretate (in loc să fie compilate), nu sunt capabile să construiasca 
controale reutilizabile care să incapsuleze functionalitati complexe pentru interactiunea cu 
utilizatorul 

e Perl (Practical Extraction and Report Language) este un limbaj de programare 

complex, precursor al PHP 

e JSP (JavaServer Pages) este o platformă de programare Web creată de Sun 

Microsystems şi face parte din specificatia Java 2 Entreprise Edition (J2EE). 
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JSP utilizeazá sintaxa XML si o serie de clase si functii Java. Codul JSP este 
compilat de servlet-uri binare pentru o procesare rapidä. 


Server-side scripting reprezintá ,programarea" comportamentului serverului, iar client-side 
scripting se refera la ,programarea" comportamentului browserului de pe client. Programarea 
la nivel de client se realizeazä in special prin JavaScript. 
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3. Programarea client - side 
Unul din primele elemente fundamentale ale WWW ( World Wide Web ) este HTML 
(Hypertext Markup Language), care descrie formatul primar in care documentele sint 
distribuite si vazute pe Web. Multe din trasaturile lui, cum ar fi independenta fata de 
platforma, structurarea formatarii si legaturile hipertext, fac din el un foarte bun format pentru 
documentele Internet si Web. 

Standardul oficial HTML este stabilit de World Wide Web Consortium (W3C), care este 
afiliat la Internet Engineering Task Force (IETF). W3C a enuntat cateva versiuni ale 
specificatiei HTML, printre care si HTML 2.0, HTML 3.0,HTML 3.2, HTML 4.0 si, cel mai 
recent, HTML 4.01. In acelasi timp, autorii de browsere, cum ar fi Netscape si Microsoft, au 
dezvoltat adesea propriile "extensii" HTML in afara procesului standard si le-au incorporat in 
browserele lor. In unele cazuri, cum ar fi tagul Netscape , aceste extensii au devenit 
standarde de facto adoptate de autorii de browsere. 


3.1. Elemente avansate de HTML 


3.1.1. Tabele 


Tabelele ne permit sà cream o retea dreptunghiulara de domenii, fiecare domeniu 
avand propriile optiuni pentru culoarea fondului, culoarea textului, alinierea textului etc. 
Pentru a insera un tabel se folosesc etichetele corespondente <table>...</table>. Un tabel 
este format din randuri. Pentru a insera un rand intr-un tabel se folosesc etichetele 
<tr>...</tr> ("table row "= rand de tabel ). 

Un rand este format din mai multe celule ce contin date. O celula de date se 
introduce cu eticheta <td>..</td>. 


«html» 
«head» 
<title>tabel</title> 
</head> 
<body> 
«h1 align=center>Un tabel simplu format din 4 linii si 2 coloane</h1> 
«hr» 
<table> 
<tr> 
<td>c11</td> 
<td>c11</td> 
</tr> 
<tr> 
<td>c21</td> 
<td>c22</td> 
</tr> 
<tr> 
<td>c31</td> 
<td>c32</td> 
</tr> 
<tr> 
<td>c41</td> 
<td>c42</td> 
</tr> 
</table> 
</body> 
</html> 
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In mod prestabilit, un tabel nu are chenar. Pentru a adauga un chenar unui tabel, se 
utilizeaza un atribut al etichetei <tabel> numit border. Acest atribut poate primi ca valoare 
orice numar intreg ( inclusiv 0 ) si reprezinta grosimea in pixeli a chenarului tabelului. Daca 
atributul border nu este urmata de o valoare atunci tabelul va avea o grosime prestabilita 
egala cu 1 pixel, o valoare egala cu 0 a grosimii semnifica absenta chenarului. Cand atributul 
border are o valoare nenula chenarul unui tabel are un aspect tridimensional. 


<table border="2"> 
«tr» 
<td>c11</td> 
<td>c11</td> 
</tr> 
</table> 


Pentru a alinia un tabel intr-o pagina Web se utilizeaza atributul align al etichetei 
«table», cu urmatoarele valori posibile: " left " ( valoarea prestabilita ), " center " si "right ". 
Alinierea este importanta pentru textul ce inconjoara tabelul. Astfel : 

e daca tabelul este aliniat stanga ( «table align="left"> ), atunci textul care 
urmeaza dupa punctul de inserare al tabelului va fi dispus in partea dreapta a 
tabelului. 

e daca tabelul este aliniat dreapta ( «table align="right"> ), atunci textul care 
urmeaza dupa punctul de inserare al tabelului va fi dispus in partea stanga a 
tabelului. 

e daca tabelul este aliniat pe centru ( <table align="center"> ), atunci textul care 
urmeaza dupa punctul de inserare al tabelului va fi afisat pe toata latimea 
paginii, imediat sub tabel. 

Culoarea de fond se stabileste cu ajutorul atributului bgcolor, care poate fi atasat 
intregului tabel prin eticheta «table», unei linii prin eticheta «tr» sau celule de date prin 
eticheta «td». Valorile pe care le poate primi bgcolor sunt cele cunoscute pentru o culoare. 
Daca in tabel sunt definite mai multe atribute bgcolor, atunci prioritatea este urmatoarea: 
«td», <tr>, «table» ( cu prioritate cea mai mica ). 


«html» 
<head> 
<title>tabel</title> 
</head> 
<body> 
<h1 align=center>Un tabel simplu colorat</h1> 
<hr> 
<table border="3" bgcolor="green"> 
<tr> 
<td>verde 11</td> 
<td bgcolor="red">rosu 11</td> 
</tr> 
<tr bgcolor="blue"> 
<td>albastru 21</td> 
<td bgcolor="yellow">galben 22</td> 
</tr> 
«tr bgcolor="cyan"> 
<td>c31</td> 
<td>c32</td> 
</tr> 
<tr> 
<td>c41</td> 
<td bgcolor="white">c42</td> 
</tr> 
</table> 
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</body> 
</html> 


Culoarea textului din fiecare celula se pote stabili cu ajutorul expresiei: 
«font color="valoare">...</font>. 

Distanta dintre doua celule vecine se defineste cu ajutorul atributului cellspacing al 
etichetei <table>.Valorile acestui atribut pot fi numere intregi pozitive, inclusiv 0, si reprezinta 
distanta in pixeli dintre doua celule vecine. Valorea prestabilita a atributului cellspacing este 
2. 

Distanta dintre marginea unei celule si continutul ei poate fi definita cu ajutorul 
atributului cellpadding al etichetei <table>.Valorile acestui atribut pot fi numere intregi 
pozitive, si reprezinta distanta in pixeli dintre celule si continutul ei. Valorea prestabilita a 
atributului cellpadding este 1. 

Dimensiunile unui tabel - latimea si inaltimea - pot fi stabilite exact prin intermediul a 
doua atribute, width si height, ale etichetei <table>.Valorile acestor atribute pot fi: 

e numere intregi pozitive reprezentand latimea respectiv inaltimea in pixeli a 
tabelului; 

e numere intregi intre 1 si 100, urmate de semnul %, reprezentand fractiunea 
din latimea si inaltimea totala a paginii. 


<html> 
<head> 
<title>tabel</title> 
</head> 
<body> 
<h1 align=center>Text</h1> 
<table width="100%" height="100%"> 
<tr> 
<td align="center"> 
<h2>Text centrat.</n2> 
</td> 
</tr> 
</table> 
</body> 
</html> 


Un tabel poate avea celule cu semnificatia de cap de tabel. Aceste celule sunt 
introduse de eticheta <th> ( de la " tabel header " = cap de tabel ) in loc de <td>. Toate 
atribute care pot fi atasate etichetei <td> pot fi de asemenea atasate etichetei <th>. 
Continutul celulelor definite cu <th> este scris cu caractere aldine si centrat. 

Alinierea pe orizontala a continutului unei celule se face cu ajutorul atributului align 
care poate lua valorile: 

e left (la stanga ); 

e center ( centrat , valoarea prestabilita ); 

e right (la dreapta ); 

e char (alinierea se face fata de un caracter ). 

Alinierea pe verticala a continutului unei celule se face cu ajutorul atributului valign 
care poate lua valorile: 

e baseline (la baza ); 

e bottom (jos); 

e middle (la mijloc, valoarea prestabilita ); 
e top (sus). 

Aceste atribute pot fi atasate atat etichetei <tr> pentru a defini tuturor elementelor 
celulelor unui rand, cat si etichetelor <td> si <th> pentru a stabili alinierea textului într-o 
singura celula. 
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Un tabel trebuie privit ca o retea dreptunghiulara de celule.Cu ajutorul a doua atribute 
ale etichetelor <td> si <th>, o celula se poate extinde peste celule vecine. 


Astfel: 

e extinderea unei celule peste celulele din dreapta ei se face cu ajutorul 
atributului colspan, a carui valoare determina numarul de celule care se 
unifica. 

e extinderea unei celule peste celulele dedesubt se face cu ajutorul atributului 
rowspan, a carui valoare determina numarul de celule care se unifica. 

Sunt posibile extinderi simultane ale unei celule pe orizontala si pe verticala. In acest 
caz , in etichetele <td> si <th> vor fi prezente ambele atribute colspan si rowspan. 


<html> 
<head> 
<title>table</title> 
</head> 
<body> 
<h1 align=center>Un tabel simplu cu chenar</h1> 
<hr> 
<table border="0"> 
<tr> 
«td rowspan="3">c11</td> 
<br>c21<br>c31</td> 
<td>c12</td> 
<td colspan="2" rowspan="3">c13 , c4</td> 
<br>c23, c24<br>c33, c34</td> 
</tr> 
<tr> 
<td>c22</td> 
</tr> 
<tr> 
<td>c32</td> 
</tr> 
<tr> 
<td>c41</td> 
<td colspan="3">c42, c43, c44</td> 
</tr> 
</table> 
</body> 
</html> 


Daca un tabel are celule vide, atunci aceste celule vor aparea in tabel fara un chenar 
de delimitare. 
In scopul de a afisa un chenar pentru celule vide se utilizeaza &nbsp in interiorul unei 
celule: 

e dupa <td> se pune &nbsp;; 
e dupa <td> se pune <br>. 

Caracterul &nbsp; ( no breakable space ) este de fapt caracterul spatiu.Un spatiu 

introdus prin intermediul acestui caracter nu va fi ignorat de browser. 


3.1.2. Frames (cadre) in HTML 


Ferestrele sau (cadrele) ne permit sa definim in fereastra browserului subferestre in 
care sa fie incarcate documente HTML diferite.Ferestrele sunt definite intr-un fisier HTML 
special , in care blocul <body>...</body> este inlocuit de blocul <frameset>...</frameset>. In 
interiorul acestui bloc, fiecare cadru este introdus prin eticheta <frame>. 
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Un atribut obligatoriu al etichetei <frame> este src, care primeste ca valoare adresa 
URL a documentului HTML care va fi incarcat in acel frame. Definirea cadrelor se face prin 
impartirea ferstrelor (si a subferestrelor) in linii si coloane: 
e impartirea unei ferstre într-un numar de subferestre de tip coloana se face cu 
ajutorul atributului cols al etichetei «frameset» ce descrie acea fereastra; 
e  impartirae unei ferestre într-un numar de subferestre de tip linie se face cu 
ajutorul atributului rows al etichetei <frameset> ce descrie acea fereastra; 
e valoare atributelor cols si rows este o lista de elmente separate prin virgula , 
care descriu modul in care se face impartirea. 
Elementele listei pot fi: 
e unnumar intreg de pixeli; 
e procente din dimensiunea ferestrei (numar intre 1 si 99 terminat cu 96); 
e n* care inseamna n parti din spatiul ramas; 
Exemplu 1: cols=200,*,50%,* inseamna o impartire in 4 subferestre, dintre care prima are 
200 pixeli, a treia ocupa jumatate din spatiul total disponibil , iar a doua si a patra ocupa in 
mod egal restul de spatiu ramas disponibil. 
Exemplu 2: cols=200,1*,50%,2* inseamna o impartire in 4 subferestre , dintre care prima 
are 200 pixeli , a treia ocupa jumatate din spatiul total disponibil iar a doua si a patra ocupa 
in mod egal restul de spatiu ramas disponibil, care se imparte in trei parti egale , a doua 
fereastra ocupand o parte , iar a patra ocupand 2 parti. 


Observatii: 

e daca mai multe elemente din lista sunt configurate cu * , atunci spatiul 
disponibil ramas pentru ele se va imparti in mod egal. 

e o subfereastra poate fi un cadru (folosind <frame>)in care se va incarca un 
document HTML sau poate fi impartita la randul ei la alte subfereste (folosind 
<frameset>). 

<html> 
<head> 
<title>frames</title> 
</head> 


<frameset cols="*,*"> 
«frame src="f1.html"> 
«frame src="f2.html"> 
</frameset> 
</html> 


In exemplul urmator este creata o pagina Web cu trei cadre mixte.Pentru a o crea se 
procedeaza din aproape in aproape. Mai intai, pagina este impartita in doua subferestre de 
tip coloana, dupa care a doua subfereastra este impartita in doua subferestre de tip linie. 


<html> 
<head> 
<title>frames</title> 
</head> 
<frameset cols="20%,*"> 
«frame src="p1.html"> 
<frameset rows="*,*"> 
«frame src="p2.html"> 
«frame src="p3.html"> 
</frameset> 
</frameset> 
</html> 


Pentru a stabili culoarea chenarului unui cadru se utilizeaza atributul bordercolor. 
Acest atribut primeste ca valoare un nume de culoare sau o culoare definita in conformitate 
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cu modelul de culoare RGB.Atributul bordercolor poate fi atasat atat etichetei <frameset> 
pentru a stabili culoarea tuturor chenarelor cadrelor incluse,cat si etichetei <frame> pentru a 
stabili culoarea chenarului pentru un cadru individual. 

Atributul border al etichetei <frameset> permite configurarea latimii chenarelor tuturor 
cadrelor la un numar dorit de pixeli. Valoarea prestabilita a atributului border este de 5 pixeli. 
O valoare de 0 pixeli va defini un cadru fara chenar. 

<html> 

<head><title>frames</title></head> 

<frameset cols="20%,*" bordercolor="green" border="15"> 

<frame src="p1.html"> 

<frameset rows="*,*"> 

<frame src="p2.html" bordercolor="blue"> <frame src="p3.html"> 
</frameset> 

</html> 


Pentru a obtine cadre fara chenar se utilizeaza border="0". In mod prestabilit, 
chenarul unui cadru este afisat si are aspect tridimensional. Afisarea chenarului unui cadru 
se poate dezactivata daca se utilizeaza atributul frameborder cu valoare "no". Acest atribut 
poate fi atasat atat etichetei <frameset> (dezactivarea fiind valabila pentru toate cadrele 
incluse) cat si etichetei <frame> (dezactivarea fiind valabila numai pentru un singur cadru). 
Valorile posibile ale atributului frameborder sunt: "yes" -echivalent cu 1; "no" 
echivalent cu 0; 


<html> 
<head><title>frames</title></head> 
<frameset cols="20%,*" border="0"> 
<frame src="p1.html"> 
<frameset rows="*,*"> 

<frame src="p2.html"> 

<frame src="p3.html"> 
</frameset> 
</html> 


Atributul scrolling al etichetei <frame> este utilizat pentru a adauga unui cadru o bara 
de derulare care permite navigarea in interiorul documentului afisat in interiorul cadrului. 
Valorile posibile sunt: 

e yes - barele de derulare sunt adaugate intotdeauna; 
e no -barele de derulare nu sunt utilizabile; 
e auto - barele de derulare sunt vizibile atunci cand este necesar 


«html» 

<head><title>frames</title></head> 
<frameset cols="*,*,*"> 

<frame src="p.html" scrolling="yes" noresize> 
<frame src="p.html" scrolling="no" noresize> 
«frame src="p.html" scrolling="auto" noresize> 
</frameset> 

</html> 


Atributul noresize al etichetei <frame> (fara nici o valoare suplimentara) daca este 
prezent, inhiba posibilitatea prestabilita a utilizatorului de a redimensiona cadrul cu ajutorul 
mouse-ului. 

Un cadru intern este specificat prin intermediul blocului <iframe>...</iframe>. Un 
cadru intern se insereaza intr-o pagina Web in mod asemanator cu o imagine sau in modul 
in care se specifica marcajul «frame», asa cum rezulta din urmatorul exemplu: «iframe 
src-"iframes ex.html" height=40% width=50%> </iframe> 

In acest caz fereastra de cadru intern care are 40%din inaltimea si 50% din latimea 
paginii curente. 
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Atributele aceptate de eticheta «iframe» sunt in parte preluate de la etichetele 
«frame» si <frameset>, cum ar 
fi:src,border,frameborder,bordercolor,marginheight,marginwidth,scrolling,name,noresize; sau 
de la eticheta «img» vspace,hspace,align,width,height; 

In mod prestabilit, la efectuarea unui clic pe o legatura noua pagina (catre care indica 
legatura) o inlocuieste pe cea curenta in aceeasi fereastra (acelasi cadru). Acest 
comportament se poate schimba in doua moduri: 

e prin plasarea in blocul <head>...</head> a unui element «base» care 
precizeaza,prin atributul target numele ferestrei (cadrului) in care se vor 
incarca toate paginile noi referite de legaturile din pagina curenta conform 
sintaxei: «base target-"nume ferastra/frame de baza"» 

e prin plasarea in eticheta «a» a atributului target, care precizeaza numele 
ferestrei (cadrului) in care se va incarca pagina nou referita de legatura, 
conform sintaxei: «a href="legatura" target="nume_fereastra/frame">...</a> 

Daca este prezent atat un atribut target in «base» cat si un atribut target in «a», 
atunci cele precizate de atributul target din «a» sunt prioritare. 

Numele unui cadru este stabilit prin atributul name al etichetei «frame» conform 
sintaxei: <farme name-"nume frame" 

In exemplul urmator este prezentata o pagina Web cu doua cadre. Toate legaturile 
din cadrul 1 incarca paginile in cadrul 2. 


«html» 

<head><title>frames</title></head> 

<frameset cols="20%,*"> 

«frame src="left.html" name="left"> 

<frame src="p.html" name="main"> 

</frameset> 

</html> 

<html> 

<head><title>frame_left</title> </head> 

<body> 

«a hrefz"p1.html" target="main"> 

Fisierul1</a><br> «a href="p2.html" target="main"> 

Fisierul2«/a» «br» <a href="p3.html" target="main"> 
Fisierul3</a><br><br> «a href="p1.html" target="_blank"> 

Fis1 intr-o fereastra noua</a><br><br> <a href="p1.html" target="_self"> 
Fis1 in fereastra curenta</a><br><br> «a href="p.html" target="main"> 
Home</a><br> 

</body> 

</html> 


Atributul target al etichetei<frame> accepta anumite valori : 

" self" (incarcarea noii pagini are loc in cadrul curent); 

e " blank" (incarcarea noii pagini are loc într-o fereastra noua anonima); 

e " parent" (incarcarea noii pagini are loc in cadrul parinte al cadrului curent 
daca acesta exista, altfel are loc in fereastra browserului curent); 

e " top" (incarcarea noii pagini are loc in fereastra browserului ce contine cadrul 
curent); 


3.1.3. Formulare 


Un formular este un ansamblu de zone active alcatuit din butoane, casete de 
selectie, campuri de editare etc. Formularele asigura construirea unor pagini Web care 
permit utilizatorilor sá introduca informatii si sá le transmita serverului. Formularele pot varia 
de la o simpla caseta de text , pentru introducerea unui sir de caractere pe post de cheie de 
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cautare, pana la o structura complexa, cu multiple sectiuni, care ofera facilitati puternice de 
transmisie a datelor. 

Un formular este definit intr-un bloc delimitat de etichetele corespondente 
«form» si </form>. 

Exista doua atribute importante ale elementului <form>. 

1. Atributul action precizeaza ce se va intampla cu datele formularului odata ce 
acestea ajung la destinatie. De regula , valoarea atributului action este adresa URL a unui 
script aflat pe un server WWW care primeste datele formularului , efectueaza o prelucrare a 
lor si expedieaza catre utilizator un raspuns. 

«form action="http://www.yahoo.com/cgi-bin/nume_fis.cgi">. 

Script-urile pot fi scrise in limbajele Perl, C, PHP, Unix shell. etc 

2. Atributul method precizeaza metoda utilizata de browser pentru expedierea datelor 
formularului. Sunt posibile urmatoarele valori: 

e get (valoarea implicita). In acest caz , datele din formular sunt adaugate la adresa 

URL precizata de atributul action; (nu sunt permise cantitati mari de date - maxim 1 

Kb ) 

e post In acest caz datele sunt expediate separat. Sunt permise cantitati mari de date 

(ordinul MB) 

Majoritatea elementelor unui formular sunt definite cu ajutorul etichetei «input». 
Pentru a preciza tipul elementului se foloseste atributul type al etichetei «input». Pentru un 
camp de editare, acest atribut primeste valoarea "text". Alte atribute pentru un element 
«input» sunt: 

e atributul name ,permite atasarea unui nume fiecarui element al formularului. 
e atributul value ,care permite atribuirea unei valori initiale unui element al 
formularului. 

Un buton de expediere al unui formular se introduce cu ajutorul etichetei «input», in 
care atributul type este configurat la valoarea "submit".Acest element poate primi un nume 
prin atributul name. Pe buton apare scris "Submit Query" sau valoarea atributului value, daca 
aceasta valoare a fost stabilita. 


«form method="post" action="mailto:youremail@youremail.com" > 
First:<input type="text" name="First" size="12 maxlength="12" /> 
Last:<input type="text" name="Last" size="24" maxlength="24" /> 
<input type="submit" value="Send Email" /> 

</form> 


Pentru elementul «input» de tipul camp de editare (type = "text") , alte doua atribute 
pot fi utile: 

e atributul size specifica latimea campului de editare depaseste aceasta latime, 
atunci se executa automat o derulare acestui camp; 

e atributul maxlength specifica numarul maxim de caractere pe care le poate 
primi un camp de editare; caracterele tastate peste numarul maxim sunt 
ignorate. 

Daca se utilizeaza eticheta <input> avand atributul type configurat la valoarea 
"password" , atunci in formular se introduce un element asemanator cu un camp de 
editare obisnuit (introdus prin type="text"). Toate atributele unui camp de editare 
raman valabile. Singura deosebire consta in faptul ca acest camp de editare nu 
afiseaza caracterele in clar, ci numai caractere *, care ascund de privirile altui 
utilizator aflat in apropiere valoarea introdusa intr-un asemenea camp. La expedierea 
formularului insa, valoarea tastata intr-un camp de tip "password" se transmite in 
clar. 
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<html> 
<head><title>forms</title></head> 


<body><h1>Un formular cu un buton reset</h1> 

<hr> 

<form action=mailto:test@yahoo.com" method="post"> 

Nume:<input type="text" name="nume" value="Numele"><br> 

Prenume:<input type="text" name="prenume" value="Prenumele"><br> 
Password:<input type="password" name="parola" ><br> 

<input type="reset" value="sterge"> <input type="submit" value="trimite"> </form></body> 
</html> 


Butoanele radio permit alegerea , la un moment dat , a unei singure variante 
din mai multe posibile. Butoanele radio se introduc prin eticheta <input> cu atributul 
type avand valoarea "radio". 


Italian: <input type="radio" name="food" /> 
Greek: «input type="radio" name="food" /> 
Chinese: <input type="radio" name="food" /> 


O caseta de validare (checkbox) permite selectarea sau deselectarea unei 
optiuni. Pentru inserarea unei casete de validare se utilizeaza eticheta <input> cu 
atributul type configurat la valoarea "checkbox". 
Fiecare caseta poate avea un nume definit prin atributul name.fiecare caseta poate 
avea valoarea prestabilita "selectat" definita prin atributul checked. 


<p>Please select every sport that you play.</p> 
Soccer: <input type="checkbox" checked="yes" name="sports" value="soccer" /> 


<br /> 

Football: <input type="checkbox" name="sports" value="football" /> 
<br /> 

Baseball: <input type="checkbox" name="sports" value="baseball" /> 
<br /> 


Basketball: <input type="checkbox" checked="yes" name="sports" value="basketball" 
/> 


Intr-o pereche "name = value" a unui formular se poate folosi intregul continut 
al unui fisier pe post de valoare. Pentru aceasta se insereaza un element <input> 
într-un formular , cu atributul type avand valoarea "file" (fisier). Atributele pentru un 
element de tip caseta de fisiere: 

e atributul name permite atasarea unui nume 

e atributul value primeste ca valoare adresa URL a fisierului care va fi expediat o 

data cu formularul. Aceasta valoare poate fi atribuita direct atributului value, se 
poate fi tastata intr-un camp de editare ce apare o data cu formularul sau poate fi 
selectata prin intermediul unei casete de tip File Upload sau Choose File care 
apare la apasarea butonului Browse... din formular; 

e atributul enctype precizeaza metoda utilizata la criptarea fisierului de 

expediat.Valoarea acestui atribut este "multipart/form-data". 

O lista de selectie permite utilizatorului să aleaga unul sau mai multe elemente 
dintr-o lista finita. Lista de selectie este inclusa in formular cu ajutorul etichetelor 
corespondente <select>si </select>. 
O lista de selectie poate avea urmatoarele atribute: 
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atributul name, care ataseaza listei un nume (utilizat in perechile "name=value" 
expediat serverului); 

atributul size, care precizeaza (printr-un numar intreg pozitiv , valoarea 
prestabilita fiind 1) cate elemente din lista sunt vizibile la un moment dat pe ecran 
(celelalte devenind vizibile prin actionarea barei de derulare atasate automat 
listei). 


Elementele unei liste de selectie sunt incluse in lista cu ajutorul etichetei 


«option». 


Doua atribute ale etichetei option se dovedesc utile: 


atributul value primeste ca valore un text care va fi expediat serverului in 
perechea "name-value"; daca acest atribut lipseste , atunci catre server va fi 
expediat textul ce urmeaza dupa «option»; 

atributul selected (fara alte valori) permite selectarea prestabilita a unui elemment 
al listei. 


«select» 

«option? Bucuresti -- B</option> 
<option>Craiova -- DJ</option> 

«option selected="yes">lasi -- IS</option> 
</select> 


O lista de selectie ce permite selectii multiple se creeaza intocmai ca o lista de 
selectie obisnuita. In plus, eticheta <select> are un atribut multiple (fara alte valori). 
Cand formularul este expediat catre server pentru fiecare element selectat al listei 
care este se insereaza cate o pereche "name=value" unde name este numele listei. 


<select multiple="yes” sizez"3" name="orase”> 
<option>Bucuresti -- B</option> 
<option>Craiova -- DJ</option> 

«option selected="yes">lasi -- IS</option> 
</select> 


Intr-un formular campuri de editare multilinie pot fi incluse cu ajutorul etichetei 
<textarea>. Eticheta are urmatoarele atribute: 


atributul cols, care specifica numarul de caractere afisate într-o linie; 
atributul rows, care specifica numarul de linii afisate simultan; 
atributul name, care permite atasarea unui nume campului de editare multilinie; 
atributul wrap, (de la "word wrap"-trecerea cuvintelor pe randul urmatorO, care 
determina comportamentul campului de editare fata de sfarsitul de linie. 
Acest atribut poate primi urmatoarele valori: 

a) " off ; in acest caz: 
intreruperea cuvintelor la marginea dreapta a editorului se produce numai cand 
doreste utilizatorul; 
caracterul de sfarsit de linie este inclus in textul transmis serverului o data cu 
formularul; 

b) " hard "; in acest caz: 
se produce intreruperea cuvintelor la marginea dreapta a editorului ; 
caracterul de sfarsit de linie este inclus in textul transmis serverului o data cu 
formularul; 

C) " soft "; in acest caz: 
se produce intreruperea cuvintelor la marginea dreapta a editorului ; 
nu se include caracterul de sfarsit de linie in textul transmis serverului o data cu 
formularul; 
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<textarea cols="20" rows="5" wrap="hard"> 
As you can see many times word wrapping is often the desired look for your textareas. 
Since it makes everything nice and easy to read. 
</textarea> 
<textarea cols="20" rows="5" wrap="hard" readonly="yes"> 
As you can see many times word wrapping is often the desired look for your text areas. 
Since it makes everything nice and easy to read. 
</textarea> 
Intr-un formular pot fi afisate butoane.Cand utilizatorul apasa un buton, se lanseaza in 
executie o functie de tratare a acestui eveniment. Limbajul HTML nu permite scrierea unor 
astfel de functii (acest lucru este posibil daca se utilizeaza limbajele Javascript sau Java). 
Pentru a insera un buton intr-un formular, se utilizeaza eticheta «input» avand atributul type 
configurat la valoarea "button".Alte doua atribute ale elementului "button" sunt: 
e atributul name, care permite atasarea unui nume butonului 
e atributul value, care primeste ca valoare textul ce va fi afisat pe buton. 
Toate elementele cuprinse intr-un formular pot avea un atribut disabled care permite 
dezactivarea respectivului element si un atribut readonly care interzice modificarea 
continutului acestor elemente. 


3.2. XML 


Xml (eXtensible Markup Language) este un limbaj care permite definirea 
documentelor ce contin informatii intr-un mod structurat. Informatia structurata dintr-un 
document xml are atat continut (cuvinte, imagini, etc.), cat si o indicatie despre rolul pe care il 
are acel continut (de exemplu continutul din sectiunea header are alt rol fata de cel din 
footer, care la randul lui e diferit de continutul dintr-un tabel al unei baze de date). Toate 
documentele au o anumita structura. Aceste structuri se construiesc utilizand marcatori. 
W3.org se ocupa de standardizarea XML-ului, si specificatiile complete ale acestui limbaj se 
afla la adresa http:/www.w3.org/TR/WD-xml . 

In HTML, atat multimea de tag-uri (marcatori), cat si semantica asociata fiecarui tag 
sunt predefinite. Spre exemplu «H1» va reprezenta intotdeauna un header de nivel 1, iar tag- 
ul <documentHTML> nu are nici un sens (nu are asociata nici o valoare semantica). 
Standardul XML nu specifica nici semantica si nici multimea de tag-uri ale limbajului. De fapt 
XML este un metalimbaj pentru definirea limbajelor bazate pe marcatori (markup language). 
Cu alte cuvinte XML permite definirea de tag-uri precum si relatia dintre acestea. Deoarece 
nu exista o multime de tag-uri predefinita, nu exista nici o semantica asociata cu acestea. 
Definirea semantica documentelor XML este o sarcina a aplicatiilor care folosesc 
documentelor respective sau a foilor de stiluri 

Avantaje XML: 

e XML descrie continutul si modul de afisare al continutului; 

e informatia este mai usor de gasit si manipulat daca este in format XML; 

e XML ofera facilitati multiple si imbunatatite de prezentare (de exemplu folosind 
browserele) 


Structura unui document XML este arborescentă: 
<book> 
«title» My First XML</title> 
«prod id="33-657" media="paper"></prod> 
<chapter>Introduction to XML 
<para>What is HTML</para> 
<para>What is XML</para> 
</chapter> 
<chapter>XML Syntax 
<para>Elements must have a closing tag</para> 
<para>Elements must be properly nested</para> 
</chapter> 
</book> 
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«book» este elementul rádáciná (root), title, prod si chapter sunt frati (siblings) si sunt copii 
(child) lui book. 


3.3. CSS - Cascading Style Sheets (foi de stil in cascada) 


Stilurile pun la dispozitia creatorilor de site-uri noi posibilitati de personalizare 
a paginilor Web. Un stil reprezinta un mod de a scrie un bloc de text ( adica anumite 
valori pentru font, marime culoare, aliniere, distante fata de margini etc). Exista doua 
modalitati de a defini un stil: 

e sintaxa CSS (Cascading Style Sheets); 
e sintaxa Javascript. 

O foaie este construitä din reguli de stil care spun unui browser cum sà arate 
un document. Regulile de stil sunt formate dupá cum urmeazá: selector ( property: 
value ) 

Declaratiile de stil multiple pentru un singur selector pot fi despártite de punct 
si virgula: 

selector í property1: value1; property2: value2 } 

Ca exemplu, urmátorul segment de cod defineste proprietátile culoare (color) 
si márime-font (font-size) pentru elementele H1 si H2: 

«head» 

<title>exemplu css</title> 

<style> 

h1 { font-size: x-large; color: red } 

h2 { font-size: large; color: blue } 

</style> 

</head> 

Orice element HTML este un posibil selector CSS1. Selectorul este elementul 
care este legatla un stil particular. De exemplu, selectorul in declaratia CSS: P { text- 
indent: 3em }, este P. 

Declaratiile CSS pot fi introduse intr-o pagina HTML in 3 moduri: inline, intern 
si extern. 

1) Declaratia inline se realizezä cu ajutorul tag-ului style. De exemplu: 

«p style="background: blue; color: white;">A new background and font color 
with inline CSS</p> 

La modul general declaratia este de forma: 

«htmltag style="cssproperty1: value; cssproperty2: value;"> </htmltag> 

O eroare des intalnita este folosirea ,” in interiorul declaratiei de mai sus: 

«p style="background: url("yellow_rock.gif");">Gresit</p> 

«p style="background: url(yellow rock.gif);"» Corect«/p» 


2) Declaraţia interna se realizează cu ajutorul tag-ului <style> ... </style> 
«html» 
<head> 
<style type="text/css"> 
p {color: white; } 
body {background-color: black; } 
</style> 
</head> 
<body> 
<p>White text on a black background!</p> 
</body> 
</html> 
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3) Declaratia externá. Atunci cánd se foloseste CSS este de preferat sá se separe 
codul HTML de cosdul CSS. De aceea, declaratiile CSS se pun de obicei intr-un fisier 
separat, cu extensia .css . Avantajele unei asemenea abordari sunt: 

e separarea conţinutului paginii de design, crescând lizibilitatea codului html 
e modificarea uşoară a design-ului unui site prin modificarea într-un singur fişier 
css decât in mai multe pagini html 
e reutilizarea uşoară a codului css 
Declaraţia externă se realizează prin intermediul tag-ului <link></link>: 


<html> 
<head> 
<link rel="stylesheet" type="text/css" href="test.css" /> 

</head> 

<body> 

<h3> A White Header </h3> 

<p> This paragraph has a blue font. The background color of this page is gray 
because we changed it with CSS! </p> 

</body> 

</html> 


Fisierul test.css trebuie sa se afle in acelasi director cu pagina html. 

In CSS se pot defini asa numitele clase. Un simplu selector poate avea diferite 
clase, astfel permitandu-i aceluiasi element sa aiba diferite stiluri. Toate tagurile din 
pagina HTML cu aceeasi clasa vor fi formatate identic. 


p.html { color: #191970 } 
p.css { color: #4b0082 } 


Exemplul de mai sus a creat doua clase, css si html pentru folosirea cu tag-ul 
P al HTML. Caracteristica CLASS (clasa) este folosita in HTML pentru a indica clasa 
unui element, ca de exemplu, 

<P CLASS = html>Doar o clasa este permisa pentru un selector. </P> 

«P CLASS = css» De exemplu, p.html.css este invalid.</P> 

«P CLASS = html>Acest rand are aceeasi culoare cu primul. </P> 


Clasele pot fi declarate fárá un element asociat: 
.note í font-size: small ) 
In acest caz, clasa note poate fi folositä cu orice element. 


Selectorii ID sunt sunt desemnati cu scopul de a defini elemente in mod 
individual si nu mai multe elemente o datä ca in cazul claselor. Un selector ID este 
desemnat folosind indicatorul "#" care precede un nume. De exemplu, un selector ID 
ar putea fi desemnat astfel: 


#text3M ( text-indent: 3em ) 
La acest selector se va face referintá in HTML folosind caracteristica ID: 
«P ID=text3M>Textul are în fata un spaţiu de mărimea a trei litere `m` </P> 


O proprietate este desemnatä unui selector pentru a-i manipula stilul. Exemplele de 
proprietáti includ color, margin, si font. 
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Pentru a descrie formatárile repetate intr-o foaie de stil, gruparea selectorilor si a 
declaraţiilor este permisă. De exemplu, toate titlurile dintr-un document ar putea primi 
declaratii identice printr-o grupare: 

H1, H2, H3, H4, H5, H6 {color: red; font-family: sans-serif } 

Toti selectorii care sunt interpusi in cadrul altor selectori vor mosteni valorile 
proprietatilor selectorilor in cadrul carora sunt interpusi, daca nu se specifica altfel. De 
exemplu, o culoare definita pentru BODY va fi aplicata si textului dintr-un paragraf. 

Exista si cazuri in care selectorul continut nu mosteneste valorile selectorului care fl 
contine, dar acestea ar trebui sa se evidentieze in mod logic. De exemplu, proprietatea 
margin-top nu este mostenita; in mod intuitiv, un paragraf nu va avea aceeasi margine de 
sus cum o va avea tot documentul (prin selectorul body). 

O listá completä a selectorilor CSS puteti gäsi la 
http://www.w3schools.com/css/default.asp 
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4. Programarea server - side cu ASP.NET 
4.1. Serverul IIS 


Microsoft Internet Information Services (IIS) este serverul de aplicatii web al Microsoft. El este o 
componenta a Windows XP: Add/Remove Programs -» Add/Remove Windows Components. 


4.2. Caracteristici ale ASP si ASP .NET 


ASP (Active Server Pages) reprezintä o tehnologie creatä de Microsoft pentru a crea 
pagini web dinamice, ce are la bazá stocarea si executia scripturilor pe serverul Web. 

Serverele Web care suporta tehnologia ASP sunt in numär de douä: 

e PWS - Personal Web Server (Windows 98, Me) si 

e  |IS-— Internet Information Server (Windows NT, 2000 si ulterior). 

Principalele caracteristici ale tehnologiei ASP sunt: 

e Permite accesarea si actualizarea usoará a bazelor de date; 

e Viteză mare de execuţie; 

e Securitate ridicată, datorită faptului că scriptul nu poate fi vizualizat în 

browser; 
e Generarea dinamică a răspunsurilor către clienţii WEB, etc. 


Microsoft .NET este o platforma de dezvoltare software, care are menirea de a oferi 
programatorilor un mediu in care sunt puse la dispozitie diverse servicii cum sunt: 
managementul firelor de executie, managementul duratei de viata a obiectelor (Garbage 
Collection), tratarea exceptiilor, etc; si care determina o viteza mult mai mare a dezvoltarii 
aplicatiilor decât direct pe platforma Win32, adica direct pe sistemul de operare Windows. 

Inovația adusă de Microsoft, constă în dezvoltarea unei platforme comune pentru mai 
multe limbaje de programare, platformă care permite dezvoltarea unei aplicaţii în orice limbaj 
doreste programatorul. Acest lucru este posibil prin dezvoltarea unui interpretor - Comon 
Language Runtime — care transformă codul de program dintr-un limbaj oarecare, compatibil 
cu platforma .NET, în limbajul Microsoft Intermediate Language. Codul rezultat în limbajul 
Microsoft Intermediate Language, se poate apoi compila pentru orice sistem de operare care 
are instalat .NET Framework. Paginile web dinamice create cu ajutorul ASP pot îngloba mai 
multe tipuri de tehnologii Web existente. De asemenea, scripturile din fisierele ASP pot fi si 
ele de mai multe tipuri :vbscript, javascript, active server) 


Caracteristicile principale ale platformei .NET, sunt: 
e Permite integrarea usoará a aplicaţiilor Windows cu cele de WEB; 
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e  Faciliteazá interoperabilitatea între aplicaţii, indiferent de platforma pentru 
care sunt create; 

Asigurá serializarea/deserializarea obiectelor; 

Asigură un mediu stabil de programare obiectuală; 

Instalare simplificată, fără conflicte între versiuni; 

Execuţia securizată a codurilor; 

Utilizează standardele existente pentru comunicare; 

Înlocuirea mediului script cu cel compilat, în cazul aplicaţiilor ASP 

Codul de program al unei aplicaţii, scris într-un anumit limbaj de programare, 
poate fi integrat fără probleme în altă aplicaţie, scrisă în alt limbaj de 
programare, etc.; 


Printre limbajele care suportă .NET, în primul rând trebuie amintite cele dezvoltate de 
Microsoft — VB .NET, C# .NET, Visual C++ .NET, cât si limbaje dezvoltate de alte firme: 
Borland CF, Cobol, Eiffel, Perl, Phython, Smalltalk, Pascal, Fortran, etc. 

Limbajele de programare dezvoltate de Microsoft, desi au toate la bazá aceeasi 
platformá, pot fi clasificate in funcNie de gradul de complexitate: 

e VB NET. este cel mai accesibil, fiind o evoluţie a mediului Visual Basic 6.0; 

e C£ NET, este un limbaj „hibrid” între complexitatea limbajului C++ si 
accesibilitatea oferitá de limbajul VB .NE T; 

e VC ** .NET — este cel mai complex, fiind o evolutie a mediului VC++ 6.0. 

ASP .NET reprezintá o evolutie a ASP bazatá pe o nouá tehnologie dezvoltatá de 
Microsoft, si anume platforma: .NET Framework. Tehnologia ASP .NET, aduce imbunátátiri 
semnificative fatä de ASP, cele mai evidente fiind urmátoarele: 

e Execuţia este mai rapidă; 

e Este independent de programul de navigare pe Internet; 

e Codul aplicaţiei este compilat si executat de server; acesta, în cazul ASP, 
este interpretat pe măsura parcurgerii scripturilor; 

e Utilizează noţiunea de code behind, adică separă partea de prezentare de 
partea de execuţie a unei aplicaţii WEB; 

e  Favorizează reutilizarea codului, ceea ce în cazul ASP simplu, era o 
problemă, singura „reutilizare” care se făcea în ASP, fiind aceea de copiere a 
codului; 

e  Serializarea/deserializarea cu usurintá a obiectelor; 

e Asigură interoperabilitatea între aplicaţii WEB, între aplicaţii WEB si alte 
categorii de aplicații; 

e Securitate crescută; 

Datorită platformei NET, pot fi înglobate cu usurintá în aplicaţiile WEB toate 
componentele care erau până acum caracteristice doar mediului Windows. 

Microsoft ASP NEI este următoarea generaţie a tehnologiei de dezvoltare a 
aplicaţiilor Web. Ea preia tot ce este mai bun de la Active Server Pages (ASP) la fel ca si 
serviciile bogate si facilitățile oferite de Common Language Runtime (CLR) si multe alte 
facilităţi noi. Rezultatul este o nouă modalitate de dezvoltare web rapidă, scalabilă si robustă 
care permite o mare flexibilitate cu foarte puţine linii de cod scrise. Web Forms reprezintă 
partea centrală pe care se bazează ASP .NET. Acestea reprezintă elementele de interfață cu 
utilizatorul care dau aplicaţiilor web aspectul si comportamentul dorit. Formularele Web sunt 
similare formularelor Windows prin faptul că oferă proprietăţi, metode si evenimente 
controalelor plasate pe ele. Totusi, aceste elemente de interfață sunt afisate prin intermediul 
limbajului HTML, iar în cazul utilizării Microsoft Visual Studio .NET poate fi folosită interfața 
familiară de tip drag-and-drop pentru crearea aspectului formularelor Web. Formularele Web 
sunt constituite din două componente: partea vizuală (fisierul .ASPX) si codul din spatele 
formularului, care este stocat în fisiere separate. 
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4.3. Crearea de aplicatii WEB folosind ASP.NET 


Pentru a crea aplicatii web cu ASP.NET avem nevoie de urmátoarele instrumente 
software: 

Microsoft Internet Information Services (IIS) este serverul de aplicatii web al 
Microsoft. El este o componenta a Windows XP: Add/Remove Programs -» Add/Remove 
Windows Components. 

Visual WebDeveloper 2005 Express Edition - este un mediu integrat de dezvoltare, 
care cuprinde inclusiv unelte de design al Form-urilor web, unelte de debug si deployment. 

Colectia de namespaces System.Web. Acestea sunt parte integranta a .NET 
Framework si include clase predefinite care se ocupa de chestiuni specifice aplicatiilor web. 

Controalele HTML si server sunt componente ale interfetei cu utilizatorul care sunt 
folosite pentru a afisa respectiv colecta informatii catre / dinspre utilizatori. 

Limbajul de programare C#. 

ADO.NET - sunt clase predefinite care se ocupa de managementul datelor — accesul 
la date in baze de date ODBC si Microsoft SQL Server. 


4.3.1. Configurarea masinii de lucru pentru proiecte ASP.NET 


Va trebui sà aveti instalate IIS si Visual WebDeveloper 2005 Express Edition, care 
instaleaza automat si .NET Framework si inregistreaza ASP.NET in IIS. 

Atentie: daca ati instalat IIS dupa .NET Framework, nu veti putea rula aplicatii 
ASP.NET. Pentru a face totusi asta, trebuie sá rulati din linia de comanda fisierul 
aspnet regiis.exe cu optiunea -i, din directorul 
C:WINDOWS\Microsoft.NET\Framework\v1.1.4322. 


4.3.2. Proiectele ASP.NET in Visual Studio NET cu C# 


Un proiect ASP.NET poate fi creat cu ajutorul Visual WebDeveloper 2005 Express 
Edition: File -> New Web Site -> ASP.NET Web Site. Se alege la optiunea Language limbajul 
C#. Se creaza automat de catre IDE urmatoarele fisiere: 

e Un Form care este de fapt un fisier Default.aspx, care poate fi vizualizat 
in doua moduri: Design si HTML. Acesta contine cod HTML si aici pot fi 
asezate prin design contoalele care ruleaza la nivel de server. 

e Fiecare fisier .aspx are asociat unul de tip ce unde este codul din spatele 
Form-ului, adica codul care este executat la nivel de server. Se poate 
ajunge la acel fisier cu click dreapta pe Form si View Code. Acest fisier 
are atasate automat cateva namespaces (folosind cuvantul cheie din 
limbajul C# using), printre care se pot observa si cele din familia 
System.Web. 

e Web.config — acesta este un fisier XML in care se pot seta mai multe 
informatii de configurare a aplicatiei web. In general, el este folosit pentru 
securitate (autentificare), dar si pentru stocarea unor informatii gen 
constante care sá poata fi regasite din codul executabil. Avantajele stocatii 
unor astfel de constante in web.config sunt: modificarile in acest fiser nu 
atrag dupa sine necesitatea de recompilare a aplicatiei, respectiv 
informatiile sunt intr-un singur loc si pot fi modificate cu usurinta. (In 
fereastra solution explorer, click dreapta pe website1, add existing item si 
apoi web.config) 

In general, se recomanda ca designul aplicatiilor (din punct de vedere al ingineriei 
software si nu vizual) sá respecte anumite criterii. Astfel, daca ne gandim la modelul 
arhitectural pe mai multe nivele: 

e User Interface Layer — Form-uri web, in care se fac afisari si de unde se 
preiau informatii de la utilizator. 

e Business Layer — clase in care se efectueaza operatiile specifice aplicatiei. 
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e Data Access Layer — clase care se ocupa cu accesul la baza de date si 
trimiterea informatiilor in nivelele superioare. 

ASP.NET vine cu cateva controale predefinite, in plus fata de cele HTML, numite si 
controale server, numite asa deoarece tratarea evenimentelor la care acestea raspund se 
executa pe server. Visual Studio .NET 2005 are o interfatá care permite manipularea facila a 
acestora din Toolbox. 

ASP.NET 2.0 vine cu peste 50 de noi astfel de controale. Toolbox-ul este alcatuit din 
tab-urile Standard, Data, Validation, Navigation, Login, WebParts, HTML si General. Fiecare 
tab contine controale specifice. 

In ASP.NET 2.0, majoritatea controalelor dispun de Smart Tasks (sau Common 
Tasks). Acestea, in functie de controlul in cauza, permit formatarea controalelor cu stiluri 
predefinite, atasarea de date, setarea modului de vizualizare etc. 

Observati ca atunci cand introduceti controale intr-un Form web, in codul "din spatele 
acestuia", adica in fisierul .cs asociat, se produc niste modificari: se creaza un nou obiect, in 
functie de ce anume ati adaugat, ca instanta al uneia dintre clasele din spatiul de nume 
System.Web.UI.WebControls. 

Exista controale folosite la afisare de date: Labels, TextBoxes; dar in mod curent se 
folosesc si unele pentru afisarea unor colectii de informatii, cum ar fi: ListBoxes, 
DropDownLists si GridViews. Acestea din urma se folosesc foarte mult in aplicatii de 
management al informatiilor, cum ar fi de exemplu una de biblioteca, unde se poate dori 
afisarea tuturor cartilor dintr-un anumit domeniu, etc. 

Controalele sunt caracterizate prin: 

e Proprietati (ID-ul controlului, Text, Font, Activare etc.) 
e Evenimente predefinite la care stiu să raspunda (de exemplu, butoanele au 
Click, textbox-urile au TextChanged, etc.) 

In momentul in care doriti să tratati un eveniment, să spunem apasarea unui buton de 
catre utilizator, trebuie să asociati un handler evenimentului predefinit Click al butonului 
respectiv. Un handler nu este altceva decât o functie, iar asocierea respectiva se poate face 
foarte usor din Visual Studio. 

Pentru cazul anterior, este suficient dublu-click pe buton, pentru ca să se creeze 
automat o metoda de tipul 

protected void ButtonX Click(object sender, EventArgs e){} 


4.3.3. Formulare in ASP.NET 


Pentru a prezenta informatii in navigatorul clientului folosim formularele Web 
ASP.NET care ofera o abstractizare in modelul de programare, un model orientat obiect si 
bazat pe evenimente. Acest mediu de lucru beneficiaza de toate facilitatile oferite de 
platforma .NET (siguranta tipurilor, mediu de executie controlat, mostenire) si reprezinta o 
inlocuire a clasicelor formulare HTML 

Componenta vizuala este reprezentata de un fisier cu extensia .aspx-actionand ca 
un container pentru HTML, text static si controale server care pot fi afisate in browser, iar 
logica aplicatiei este reprezentata de un fisier cu extensia .cs (pentru limbajul Visual C£) sau 
.vb (pentru Visual Basic.NET). Fisierele .aspx mai sunt referite ca pagini ASP.NET. Aceasta 
tehnica de separare a codului de partea de prezentare este numita"code-behind 
programming" 

Formularele Web si ASP NET au fost create pentru a depäsi cáteva dintre limitärile 

ASP. Principalele facilitáti noi sunt redate in continuare: 
e Separarea interfeţei HTML de logica aplicaţiei 
e Un set bogat de controale pentru server ce detectează tipul browserului si 
generează limbaj HTML corespunzător acestuia 
e Mai putin cod de scris din cauza modului in care sunt construite noile 
controale server 
e Model de programare bazat pe evenimente 
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e Cod compilat si suport pentru mai multe limbaje de programare, fată de ASP 

care era interpretat ori ca VBScript ori ca Jscript 

° Permite crearea de controale de către terti care să aducă noi funcționalități. 

Logica aplicatiei reprezinta in fapt o clasa care extinde functionalitatea clasei 
System.Web.Ul.Page. Aceasta clasa contine metode care trateaza diferite evenimente ce 
apar in timpul executiei formularului Web la server (de exemplu, daca metoda Page Load 
este conectata la evenimentul Load al clasei de baza Page, atunci aceasta este apelata la 
fiecare acces al unui formular Web), proprietati (de exemplu, prin proprietatea IsPostBack 
putem afla daca o pagina Web este la primul acces sau la accesari ulterioare), atribute 
corespunzatoare unor controale din pagina WebForms si alte date membre necesare 
implementarii aplicatiei. 

O pagina WebForms, la procesarea pe serverul Web, poate fi privita ca un program 
executabil pentru care iesirea standard o reprezinta browserul sau dispozitivul client. In acest 
model, pagina trece prîntr-o serie de stagii de procesare: initializare, procesare si eliberare. 
In ordinea aparitiei, acestea sunt: 

e Init, eveniment care initializeaza pagina si in care proprietatile controalelor 
sunt actualizate. Aici este corect să initializam controale care se adauga dinamic la pagina 
sau variabile necesare inainte de initializarea paginii; 

e Load poate fi numit locul in care utilizatorul isi initializeaza codul. Evenimentul 
este generat de fiecare data cand pagina este incarcata dupa ce controalele au fost 
initializate la pasul anterior; 

e Tratarea evenimentelor utilizator, reprezinta stagiul in care sunt tratate 
evenimentele generate de client cum ar fi: schimbarea unui text într-un control, apasarea 
unui buton etc. Trebuie retinut ca aceste evenimente nu sunt tratate într-o anumita ordine pe 
server, iar tratarea lor are loc dupa aparitia unui eveniment Click care trimite formularul la 
server (a unui submit); 

e PreRender, eveniment care poate fi folosit pentru a face ultimile actualizari 
asupra paginii Web inainte ca aceasta să fie generata la client; 

e Render, eveniment care genereaza la client reprezentarea HTML a paginii 
Web ASP.NET incarcata la server; 

e Unload este ultimul eveniment care se executa inainte ca pagina să fie 
eliberata. Evenimentul este util de folosit atunci cand dorim să efectuam ultimele operatii de 
eliberare a resurselor: inchiderea fisierelor, a conexiunilor la baza de date si eliberarea 
obiectelor din memorie. 


4.3.4. Controale în ASP.NET 


Exista doua tipuri de baza in care pot fi impartite controalele: 

e HTML Controls, reprezinta elemente HTML care pot fi programate la nivelul 
serverului si expun un model obiectual restrictionat la capabilitatile 
elementelor HTML pe care le afiseaza; 

e Web Controls, aduc facilitati superioare controalelor HTML incluzand 
controale mult mai complexe, cum ar fi controlul calendar, iar modelul obiect 
nu reflecta neaparat sintaxa HTML. 

Controalele HTML sunt asemenea elementelor HTML folosite cu ajutorul Frontpage 
sau al oricărui alt editor HTML. Pot fi folosite si elementele standard HTML într-un Formular 
Web, de exemplu pentru a crea o casetă de text: <input type="text" id=txtFirstName 
size=25> 

Orice element poate fi însă marcat să ruleze ca si un control HTML atunci când 
formularul este procesat de server prin adăugarea textului "runat=server" în interiorul tagului. 

«input type-"text" id=txtFirstName size=25 runat=server> 
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În cazul folosirii Visual Studio NET, adăugarea acestui text ce permite procesarea 
controlului de către server se poate face foarte simplu dând clic dreapta pe elemental HTML 
în Design View si selectând Run as Server Control din meniul contextual. 

Controalele HTML permit de asemenea tratarea evenimentelor asociate cu tagul 
HTML (clic pe un buton, de exemplu) si manipularea în mod programatic a tagului prin codul 
din Formularul Web. In momentul în care controlul este afisat în browser, tagul este afisat 
exact asa cum a fost salvat ca si cum a fost salvat pe Formularul Web, mai puNin textul 
„runat=server”, ceea ce oferă un control foarte precis a ceea ce va fi trimis către browser. 

ASP.NET defineste un al doilea tip de controale - Web Controls. Numite si controale 
inteligente, ele pot fi caracterizate prin: 

e ofera un bogat si consistent model obiectual de programare; 

e detecteaza automat tipul navigatorului, iar afisarea la client va fi optimizata in 
functie de capabilitatile acestuia; 

e pentru unele controale se pot defini sabloane (template-uri) de afisare; 

e posibilitatea de a controla generarea evenimentelor pe server; 

e posibilitatea de a trimite evenimente unui container din interiorul acestuia (de 
exemplu, un control de tip buton in interiorul unui tabel); 

e legarea la surse de date a tuturor proprietatilor controalelor pentru a influenta 
afisarea la executie. 

Sunt definite in spatiul de nume System.Web.Ul.WebControls si mostenesc, direct 
sau indirect, clasa de baza WebControl. 


4.3.5. Pastrarea informatiilor 


Avand in vedere ca ne referim la aplicatii ASP.NET, trebuie să tinem cont de faptul ca 
fiecare Form se executa pe server si la fiecare incarcare a sa, obiectele pe care le contine 
acesta, si pe care noi dorim să le folosim, nu isi pastreaza valoarea, adica sunt setate pe 
null. Deci la navigarea într-un Form nou si incarcarea acestuia, in mod normal nu se retin 
obiectele folosite in cel anterior. 

Mai trebuie observat faptul ca fiecare Form se reincarca (se executa Page Load) la 
fiecare raspuns al serverului pentru un eveniment (cum ar fi apasarea unui buton). 

Se impune deci să pastram starea obiectelor pe care dorim să le folosim, chiar daca 
nu parasim Form-ul curent. 

Exista urmatoarele modalitati de a pastra informatii utile: Query Strings, Cookies, 
View State, Session State, Application State. 

Session State: Variabilele din Session pot fi create in timpul executiei, iar acesta 
poate fi imaginat ca un cos in care depunem obiecte pe care dorim să le pastram pe durata 
intregii executii a aplicatiei de catre utilizatorul curent. Astfel ar arata crearea unui nou obiect 
in Session: 

Session['Feedback"] = objFeedback; 

lar “luarea” lui din Session: 

objFeedback = (Feedback)Session["Feedback"]; 

Se observa ca s-a facut o conversie de tip. In Session, toate variabilele sunt de tip 
object, iar atribuirea se face unui obiect de tip Feedback (o clasa definità de utilizator). 


4.3.6. Navigarea intre Forms cu pastrarea informatiilor 


Exista mai multe posibilitati de a naviga intre Form-urile unei aplicatii ASP.NET. 

Controlul Hyperlink si metoda Response.Redirect() fac acelasi lucru, diferenta fiind ca 
primul este un control care rezida in .aspx, iar metoda se apeleaza din cod (.aspx.cs). 

Medoda Server.Transfer(), face acelasi lucru doar ca asa se pot retine informatii din 
Form-ul sursa si folosite in cel destinatie. Daca setam parametrul preserveForm al metodei la 
valoarea true, atunci QueryString si ViewState din sursa vor fi vizibile in destinatie. Totusi, 
pentru a le folosi, va trebui sá setam atributul EnableViewStateMac din directiva Page 
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(fisierul .aspx) pe valoarea false. Deoarece in mod normal informatia din ViewState este 
hash-uita, iar asa nu va mai fi, deci se va putea citi la nevoie 


4.3.7. Securitatea in ASP.NET 


Exista mai multe moduri de a securiza o aplicatie ASP.NET. In general, se poate face 
acest lucru atat din IIS Management Console (click dreapta pe un director virtual din IIS, 
Properties, Directory Security, Edit) — unde se pot alege mai multe tipuri de autentificare 
(Anonymous, Windows Integrated, Digest for Windows domain servers, Basic). 

Pe de alta parte, securizarea aplicatiei se poate face din ASP.NET. Pentru asta se 
foloseste fisierul de configurare web.config, dupa cum se vede mai jos. Forms poate fi 
inlocuit cu Windows sau Passport. 

«authentication mode="Forms"> 

In primul rand, trebuie totusi sá vorbim de aplicatii publice care nu necesita nici un fel 
de autentificare. Trebuie sá fiti atenti, acesta este modul implicit in care este creata o noua 
aplicatie ASP.NET. Atunci cand se creeazá un proiect ASP.NET cu Visual Studio, se creaza 
o aplicatie web accesibila anonim. 

In momentul in care in IIS se activeazá Anonymous Access pe un director virtual 
(adica pe o aplicatie web), atunci cand un utilizator acceseaza aplicatia, el ia automat contul 
IUSR «numele masinii», care in mod normal se afla in grupul de utilizatori Guest pe orice 
masina. Acest cont trebuie sà aibä dreptul de a citi fisierele care sunt necesare aplicatiei. De 
exemplu, daca aplicatia foloseste la un moment dat Form-ul “Student.aspx”, atunci 
IUSR «numele masinii» trebuie sa aiba dreptul de a citi fisierul de pe hard-disk 
corespunzator, să spunem *cMnetpubWwwwrootMibraryNstudent.aspx". 

Pentru o aplicatie securizata, avem mai multe posibilitati de autentificare, cele mai 
des intalnite fiind sintetizate in tabelul de pe slide. Implementarea politicii de securitate se 
poate face atat din IIS cat si din aplicatia ASP.NET. 


Aplicatie web Anonim Nu avem nevoie de 
publica pe Internet. securizare. 

Aplicatie web Windows Acest mod autentifca 
pentru Intranet. Integrated utilizatorii folosind lista de useri 


de pe server (Domain 
Controller). Drepturile userilor 
in aplicatia web este dat de 
nivelul de privilegii al contului 


respectiv. 

Aplicatie web Windows Utilizatorii companiei 
disponibila pe Integrated pot accesa aplicatia din afara 
Internet, dar cu Intranetului, folosind conturi din 
acces privat. lista serverului (Domain 

Controller). 

Aplicatii web Forms Aplicatii care au nevoie 

comerciale. Authentication de informatii confidentiale si 


eventual in care sunt mai multe 
tipuri de utilizatori. 
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4.3.7.1.1 Windows Authentication 


In acest mod de autentificare, aplicatia ASP .NET are incorporate procedurile de 
autentificare, dar se bazeazá pe sistemul de operare Windows pentru autentificarea 
utilizatorului. 

1. Utilizatorul solicita o pagina securizata de la aplicatia Web. 

2. Cererea ajunge la Serverul Web IIS care compará datele de autentificare ale 
utilizatorului cu cele ale aplicatiei (sau ale domeniului) 

3. Dacá acestea douá nu corespund, IIS refuzá cererea utilizatorului. 

4. Calculatorul clientului genereazá o fereastrá de autentificare, 

5. Clientul introduce datele de autentificare, dupá care retrimite cererea cátre IIS 

6. IIS verificá datele de autentificare, si in cazul in care sunt corecte, directioneaza 
cererea cátre aplicatia Web. 

7. Pagina securizata este returnata utilizatorului. 


4.3.7.1.2 Forms-Based Authentication 


Atunci cánd se utilizeazá autentificarea bazatá pe formulare, IIS nu realizeazá 
autentificarea, deci este necesar ca in setárile acestuia sà fie permis accesul anonim. 

1. In momentul in care un utilizator solicitá o paginä securizatä, IIS autentificä clientul 
ca fiind un utilizator anonim, dupá care trimite cererea cátre ASP.NET. 

2. Acesta verifică pe calculatorul clientului prezenţa unui anumit cookie 1 

3. Dacă cookie-ul nu este prezent sau este invalid, ASP .NET refuză cererea 
clientului si returnează o pagină de autentificare (Login.aspx). 

4. Clientul completează informaţiile cerute în pagina de autentificare si apoi trimite 
informaţiile 

5. Din nou, IIS autentifică clientul ca fiind un utilizator anonim si trimite cererea către 
ASP NET 

6. ASP NET autentifica clientul pe baza informaţiilor furnizate. De asemenea 
generează si un cookie. 

Cookie reprezintă un mic fisier text ce păstrează diverse informaţii despre utilizatorul 
respectiv, informaţii folosite la următoarea vizită a să pe site-ul respectiv, la autentificare, sau 
în diverse alte scopuri. 

7. Pagina securizată cerută si noul cookie sunt returnate clientului. Atâta timp cât 
acest cookie rămâne valid, clientul poate solicita si vizualiza orice pagină securizată ce 
utilizează aceleasi informaţii de autentificare. 


4.3.7.1.3 Passport Authentication 


La utilizarea Serviciului Web Microsoft Passport, nici IIS nici aplicaţia Web nu se 
ocupă de autentificarea clientului. Atunci când utilizatorul cere o pagină securizată, cererea 
este trimisă mai întâi serverului IIS. 

1. IIS autentificä clientul ca utilizator anonim si trimite cererea către ASP NET, 

2. Acesta verifică prezenţa unui anumit cookie pe calculatorul clientului. 

3. Dacă cookie-ul nu există, cererea este refuzată si clientul este direcționat către 
site-ul Web Passport.com pentru autentificare. 

4. Site-ul Passport.com generează un formular de Login pe care îl trimite utilizatorului 

5. Utilizatorul completează cu datele corespunzătoare si le trimite înapoi către 
Passport.com. 

6. Dacă informaţiile introduse se potrivesc cu cele din baza de date Passport.com, clientul 
este autentificat si primeste un cookie corespunzător informaţiilor introduse. 


4.4. ADO.NET 


ADO.NET este componenta din .NET Framework care se ocupa cu accesul la baze 
de date ; este standardizata in sensul ca se pot folosi aceleasi obiecte pentru accesarea 
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diferitelor tipuri de baze de date : Access, MS SQL Server, Oracle, etc. Sunt necesare la 
referinte doua namespaces ` System.Data si System.Data.SqlClient pentru MS SQL sau 
System.Data.OleDb pentru Access. 

Mecanismul accesarii bazelor de date in ADO.NET este urmatorul: un obiect 
Connection stabileste o conexiune intre aplicatie si baza de date. Aceasta conexiune poate fi 
accesata direct de un obiect Command sau de un obiect DataAdapter. Obiectul Command 
executa o comanda asupra bazei de date. Daca se returneaza valori multiple, se utilizeaza 
un obiect DataReader care va contine datele returnate. Aceste date pot fi procesate direct de 
de aplicatie. Alternativ, se poate utiliza un DataAdapter pentru a popula un obiect DataSet. 
Modificarile asupra bazei de date se pot efectua prin intermediul unui obiect Command sau 
unui obiect DataAdapter. 

Connection reprezinta conexiunea curenta la baza de date. 

Tipuri de conexiuni: 

e SqlConnection - pentru conectarea la SQL Server 7 sau versiuni ulterioare 

e OleDbConnection - conexiuni la diverse tipuri de baze de date 

e ODBCConnection 

e OracleConnection 

Un obiect Connection contine toate informatiile necesare deschiderii unui canal de 
comunicatie cu baza de date in cadrul proprietatii ConnectionString. Sunt incorporate, de 
asemenea, metode pentru facilitarea tranzactiiilor. 

Command este reprezentat de doua clase: SqlCommand si OleDbCommand Utilizat 
pentru a efectua apeluri de proceduri stocate sau de comenzi SQL asupra bazei de date sau 
pentru a returna tabele. 

Metode: 

e ExecuteNonQuery - executa comenzi care nu returneaza inregistrari - 
INSERT, UPDATE, DELETE 

e  ExecuteScalar - returneaza o singura valoare dintr-o interogare 

e ExecuteReader - returneaza o multime rezultat, sub forma unui obiect 
DataReader 

DataReader 

e contine un recordset bazat pe conexiune, forward-only, read-only 

e obiectele DataReader nu pot fi instantiate direct, sunt returnate ca rezultat al 
metodei  ExecuteReader a unui obiect Command (SqlCommand - 
SqlDataReader etc) 

e o singura linie din recordset este in memorie la un moment dat, deci se 
foloseste un minim de resurse, dar este necesara mentinerea activa a unui 
obiect Connection pe durata de viata a obiectului DataReader 

DataAdapter este clasa din nucleul tehnologiei ADO.NET, bazata pe mecanismul 
non-conexiune. 

e faciliteaza comunicarea intre baza de date si DataSet 

e populeaza obiectele DataTable sau DataSet ori de cate ori se apeleaza 
metoda Fill 

e metoda Update inregistreaza modificarile, efectuate local, in baza de date 

La apelul metodei Update, se copie modificarile din DataSet in baza de date, 
executandu-se una din comenzile reprezentate de InsertCommand, DeleteCommand sau 
UpdateCommand. 

Exista controale folosite la afisare de date: Labels, TextBoxes - informatii unicate; 
dar in mod curent se folosesc si unele pentru afisarea unor colectii de informatii, cum ar fi: 
ListBoxes, DropDownLists si GridViews. Acestea din urma se folosesc foarte mult in 
aplicatii de management al informatiilor, cum ar fi de exemplu una de biblioteca, unde se 
poate dori afisarea tuturor cartilor dintr-un anumit domeniu, etc. 
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4.4.1. Obiectele ADO.Net 


4.4.1.1.1 SqIConnection 


Un obiect SqIConnection este la fel ca orice alt obiect C#. de cele mai multe ori 

declararea si instantierea se face in acelasi timp: 

SqiConnection sqlConn = new  SqlConnection( "Data Source=(local);Initial 
Catalog=Northwind;Integrated Security=SSPI"); 

SqIConnection sqIConn1 = new SqIConnection("Data Source=DatabaseServer;lnitial 
Catalog=Northwind;User IDzYourUserlD;PasswordzYourPassword"); 

OleDbConnection oleDbConn = new 
OleDbConnection("Provider=Microsoft.Jet.OLEDB.4.0;Data Source=MyDatabase.mdb"); 


Obiectul SqIConnection de mai sus este instantiat folosind un constructor care 
primeste ca parametru un string. Acest argument este stringul de conectare. 

Scopul instantierii unui obiect de tip SqIConnection este ca alte obiecte ADO.Net sà 
poata lucra cu baza de date. Alte obiecte, cum ar fi SglDataAdapter si SqICommand, au 
constructori care primesc obiectul conexiune ca parametru. Atunci cand se lucreaza cu o 
baza de date trebuie urmati pasii: 

Instantierea unui obiect SqlConnection; 

Deschiderea conexiunii; 

Trimiterea conexiunii ca parametru altor obiecte ADO.Net; 
Realizarea operatiunilor asupra bazei de date; 

Inchiderea conexiunii. 
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4.4.1.1.2 SqICommand 

Obiectele de tipul SqlCommand permit specificare tipului de actiune asupra bazei de 
date. De exemplu se poate face o interogare, inserare, modificare sau stergere. 

Atunci cand se realizeaza o interogare in baza de date, se obtine un tabel rezultat 
care trebuie să poata fi vizualizat. Pentru a obtine acest lucru folosind obiecte SglCommand 
este folosita metoda ExecuteReader care intoarce un obiect de tipul SqlDataReader. 
Exemplul de mai jos arata modul de obtinere a unei instante salDataReader. 

SqlCommand cmd = new SqlCommand ("SELECT CategoryName FROM Categories", 
conn); 
SqlDataReader rdr = cmd.ExecuteReader(); 

Pentru a insera valori într-o baza de date trebuie apelata functia ExecuteNonQuery 

pe un obiect SqlCommand. Exemplul urmator arata modul de inserare într-o baza de date. 


string insertString = @"INSERT INTO Categories (CategoryName, Description) 

VALUES ('Miscellaneous', Whatever doesn't fit elsewhere')"; 
SqlCommand cmd = new SqlCommand (insertString, conn); 
cmd.ExecuteNonQuery(); 


Modificarea si stergerea datelor dintr-o baza de date se face la fel ca si inserarea, 
dar ca punem primul parametru al constructorului SqlCommand pe valoarea 
corespunzatoare. 

Uneori avem nevoie dintr-o baza de date doar de o singura valoare, care poate fi 
suma, media, etc. inregistrarilor dintr-un tabel. Apeland ExecuteReader si apoi calculand 
acea valoare in program nu este cea mai eficienta metoda de a ajunge la rezultat. Cea mai 
buna metoda este sà lasam baa de date sä faca ceea ce este necesar si sä intoarca o 
singura valoare. Acest lucru il face metoda ExecuteScalar: 


SqlCommand cmd = new SglCommand ("SELECT count(*) FROM Categories", conn); 
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int count = (int) cmd.ExecuteScalar(); 


4.4.1.1.3 SglDataReader 

Tipul SqlDataReader este folosit pentru a citi date in cea mai eficienta metoda 
posibila. NU poate fi folosit pentru scriere. O data citita o informatie nu mai poate fi citita inca 
o data. SqlDataReader citeste secvential date. 

Datprita faptului ca citeste doar inainte (forward-only) permite acestui tip de date sà 
fie foarte rapid in citire. Overhead-ul asociat este foarte mic (overhead generat cu 
inspectarea rezultatului si a scrierii in baza de date). Daca intr-o aplicatie este nevoie doar 
de informatii care vor fi citite o singura data, sau rezultatul unei interogari este prea mare ca 
sá fie retinut in memorie (caching) SglDataReader este solutia cea mai buna. 

Obtinerea unei instante de tipul SglDataReader este putin diferita de instantierea 
normala - trebuie apelata metoda ExecuteDataReader. Daca pentru instantiere este folosit 
operatorul new veti obtine un obiect cu care nu puteti face nimic pentru ca nu are o 
conexiune si o comanda atasate. 

SqlDataReader obtine datele într-un stream secvential. Pentru a citi aceste informatii 
trebuie apelata metoda Read; aceasta citeste un singur rand din tabelul rezultat. Metoda 
clasica de a citi informatia dintr-un SqlDataReader este de a itera într-o bucla while asa cum 
se vede in figura 4 la liniile 32-35. 

Metoda Read intoarce true cat timp mai este ceva de citit din stream. 


4.4.1.1.4 
4.4.1.1.5 Instalarea unei aplicații web pe serverul IIS 


Evident ca dupa dezvoltarea unei aplicatii, ea trebuie livrata beneficiarului. Pentru ca 
ea să mearga, este nevoie să fie “depusa” pe serverul acestuia de web. In primul rand, 
fisierele trebuie copiate undeva pe hard-disk-ul serverului web (nu neaparat in calea 
predefinita ...\Inetpub\wwwroot\). Dupa aceea, in IIS-ul server-ului web, trebuie creat un nou 
director virtual, care să indice catre calea directorului fizic unde se afla de fapt aplicatia. 

Deci, dupa ce ati depus proiectul ASP.NET pe serverul web (asta se face prin simpla 
copiere), mergeti in IIS, click dreapta pe Default Web Site, New -> Virtual Directory, alegeti 
un Alias (acesta va fi de fapt numele aplicatiei asa cum va fi ea vazuta din afara), navigati la 
calea directorului propriu-zis si ... gata. Acum, aplicatia va putea fi referita din exterior cu 
numele: http://<nume_server>/<alias> ; unde «nume server» este de fapt situl principal 
expus de serverul web, iar «alias» este ce ati ales voi la crearea directorului virtual in IIS. 

Evident, trebuie neaparat să aveti grija de securizarea aplicatiei daca este cazul, 
dupa cum se vede si in paragraful precedent. 


4.4.2. Configurare, mentenanta 


Avantajele folosirii unui fisier web.config. In primul si in primul rand, să ne imaginam o 
aplicatie de E-Commerce care lucreaza cu un server de baze de date si să ne imaginam ca 
noi facem aplicatia si o dam la mai multi clienti. 

In mod evident, serverul de baze de date se va numi in mod diferit la fiecare client. 
Cum facem deci să putem livra aplicatia clientilor, fara a recompila codul la fiecare ? Cum 
facem conexiunea la baza de date pentru fiecare client ? Ei bine, folosim web.config : 


<appSettings> 
«add key-"Database" value="Data Source-MISHUMMISHUSQL;Initial 
Catalog-elearning;User Id-***;Password-***" /> 
</appSettings> 


Dupa cum se poate vedea aici, am pus o inregistrare care contine chiar un string de 
conexiune la baza de date. Cum fac conexiunea in aplicatia mea ? Caut in web.config o 
cheie cu numele « Database ». lata: 
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public static SqIConnection ConnectToDB() 
( 
string strParameters; 
System. Configuration. AppSettingsReader apsr - new 
System. Configuration. App SettingsReader(); 
strParameters = (string)apsr.GetValue("Database" typeof(string)); 
SglConnection sqIConn = new SqlConnection(strParameters); 
return sq/Conn; 
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I.Programa scolarä reper obligatoriu pentru un demers flexibil 


Programa scolarä este parte a Curriculumului national. Termenul de curriculum derivá din limba latiná 
unde, printre altele inseamna drum cátre. 

Programa scolarä descrie oferta educationalá a unei anumite discipline pentru un parcurs scolar determinat 
Filosofia contemporaná a educatiei a evidentiat diferenta dintre o educatie bazatá pe curriculum, adicá 
având ca element central la toate etajele sale activiatea de proiectare şi programa analitică, care are in 
centrul activitätii didactice ideea de programare a traseului elevului cátre un tel cunoscut si impus doar de 
cátre adulti. 

Conceptual, programele scolare actuale, se diferentiazä de ,,programele analitice" prin accentul pe care il 
pun pe interiorizarea unui mod de gändire specific fiecärui domeniu transpus in scoalá prin intermediul unui 
obiect de studiu, nu pe succesiunea continuturilor si pe numárul de ore alocat lor. 

Actualele programe scolare subliniazá importanta rolului reglator al achizitiilor elevilor in plan formativ. 
Centrarea pe competente reprezintá modalitatea care face ca sintagma centrarea pe elev sá nu rámáná o 
lozincá fárá continut. 


Proiectarea curriculumului pe competente vine in intámpinarea cercetärilor din psihologia cognitivá, 
conform cárora prin competentá se realizeazä in mod exemplar tranferul si mobilizarea cunostintelor si a 
depriderilor in situatii/contexte noi si dinamice. 

Modelul de proiectare curriculará centrat pe competente simplificá structura curriculumului si asigurá o mai 
mare eficientá a proceselor de predare/invátare si evaluare. Acesta permite operarea la toate nivelurile cu 
aceeagi unitate: competenta, in másurá sá orienteze demersurile agentilor implicati in procesul de educatie: 


* conceptorii de curriculum; * inspectorii; 
° specialiştii în evaluare; ° elevii; 
* profesorii; ° părinții. 


Fără a intra în detalii conceptuale, formulăm câteva definiţii de lucru necesare pentru explicarea manierei în 

care au fost concepute programele şcolare. 

Definim competențele ca fiind ansambluri structurate de cunoştinţe şi deprinderi dobândite prin învăţare; 

acestea permit identificarea şi rezolvarea în contexte diverse a unor probleme caracteristice unui anumit 

domeniu. 

Structura programei şcolare cuprinde: o notă de prezentare, competenţe generale, competenţe specifice şi 

conţinuturi, valori şi atitudini, sugestii metodologice. 

v  Competenţele generale se definesc pe obiect de studiu şi se formează pe durata învăţământului liceal. 
Ele au un grad ridicat de generalitate şi complexitate şi au rolul de a orienta demersul didactic către 
achizițiile finale ale elevului. 

v Competentele specifice se definesc pe obiect de studiu si se formează pe parcursul unui an şcolar. Ele 
sunt derivate din competențele generale, fiind etape în dobândirea acestora. Competentelor specifice li se 
asociază prin programă unităţi de conţinut. 

Componenta fundamentală a programei este cea referitoare la competenţe specifice şi conţinuturi. 

Pentru a asigura o marjă cât mai largă de acoperire a obiectelor de studiu, s-a pornit de la o diferențiere cât 

mai fină a etapelor unui proces de învăţare. Acestora le corespund categorii de competenţe organizate în 

jurul câtorva verbe definitorii, ce exprimă complexe de operaţii mentale: 

1. Receptarea - concretizată prin următoarele concepte operaţionale: 


-identificarea de termeni, relaţii, procese; - nominalizarea unor concepte; 

- observarea unor fenomene, procese; - culegerea de date din surse variate; 

- perceperea unor relaţii, conexiuni; - definirea unor concepte. 

2. Prelucrarea primară (a datelor) - concretizată prin următoarele concepte operaţionale: 

- compararea unor date, stabilirea unor relaţii; - sortarea-discriminarea; 

- calcularea unor rezultate partiale; - investigarea, descoperirea, explorarea; 
- clasificarea datelor; - experimentarea. 


- reprezentarea unor date; 
3.Algoritmizarea - concretizatá prin urmatoarele concepte operationale: 
-reducerea la o schemá sau model; | -anticiparea unor rezultate; 
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-remarcarea unor invarianti; 
-reprezentarea datelor 


-rezolvarea de probleme prin modelare si 
algoritmizare. 


4.Exprimarea - concretizata prin urmatoarele concepte operationale: 
-descrierea unor stári, sisteme, procese, fenomene; -argumentarea unor enunturi; 
-generarea de idei; -demonstrarea. 


5.Prelucrarea secundará (a rezultatelor) — concretizatá prin urmatoarele concepte operationale: 


-compararea unor rezultate, date de iesire, concluzii; -elaborarea de strategii; 
-calcularea, evaluarea unor rezultate; -relationári intre diferite tipuri de reprezentäri, 
-interpretarea rezultatelor; intre reprezentare s1 obiect. 


-analiza de situatii; 
6. Transferul, care poate fi concretizat prin urmatoarele concepte operaţionale: 


-aplicarea in alte domenii; -transpunerea intr-o alta sferä; 
-generalizarea si particularizarea; -negocierea; 
-integrarea unor domenii; -realizarea de conexiuni intre rezultate; 
-verificarea unor rezultate; -adaptarea si adecvarea la context. 

I 


-optimizarea unor rezultate; 


Competentele generale ce se urmáresc a fi formate la elevi pe parcursul treptei liceale de scolarizare 
precum si competentele specifice fiecárui an de studiu, derivate din acestea, se stabilesc pornind de la modelul 
de generare prin gruparea categoriilor de concepte operationale in functie de dominantele avute in vedere. 


v Valorile si atitudinile apar in mod explicit sub forma unei liste separate in programa fiecărui obiect 
de studiu. Ele acoperá intreg parcursul invátámantului liceal si orienteazá dimensiunile axioiogicd si 
afectiv-atitudinală aferente formării personalitaiii din perspective fiecărei discipline. Realizarea lor 
concretă derivă din activitatea didactică permanentă a profesorului, constituind un implicit al acesteia. 
Valorile si atitudinile au o importanță egală în reglarea procesului educativ ca şi competențele - care 
acoperă dimensiunea cognitiva a personalităţii - dar se supun altor criterii de organizare didactico- 
metodică şi de evaluare. 


v Sugestiile metodologice cuprind recomandări generale privind metodologia de aplicare a programei. 
Aceste recomandari se pot referi la: 
- desfasurarea efectivă a procesului de predare/invátare, centrat pe formarea de competente: 
- identificarea celor mai adecvate metode şi activităţi de învăţare; 
- dotări/materiale necesare pentru aplicarea în condiţii optime a programei; 
- evaluarea continuă. 


Dincolo de structura unitară a programelor şcolare, curriculumul naţional actual propune o ofertă flexibilă, 
ce permite profesorului adaptarea cadrului formal la personalitatea sa şi la specificul clasei de elevi cu care 
lucrează. Elementele care asigură acest reglaj sunt: 

- posibilitatea intervenţiei profesorului în succesiunea elementelor de conţinut, cu condiţia asigurării 
coerentei tematice şi a respectării logicii interne a domeniului; 

- lipsa prescrierii de la centru a intervalului de timp alocat elementelor de conţinut; 

- posibilitatea modificării, a completării sau a înlocuirii activităților de învățare, astfel încât acestea să 
permită un demers didactic personalizat. 


Il.Aplicarea programelor şcolare 


Existența unor programe centrate pe achiziţiile elevilor determină un anumit sens al schimbării în didactica 
fiecărei discipline. Tabelul de mai jos prezintă în antiteză caracteristici ale procesului de predare-invátare din 
didactica tradiționala şi didactica actuală. 


Criterii Strategii didactice 


Orientare tradițională Orientare modernă 


Rolul elevului |Urmáreste prelegerea, expunerea, explicația |Exprimä puncte de vedere proprii. 
profesorului. 


Încearcă sa retina şi sa reproducă ideile auzite |Realizează un schimb de idei cu ceilalți. 
Acceptă în mod pasiv ideile transmise. Argumenteazá; pune si îşi pune întrebări cu sco- 
pul de a înţelege, de a realiza sensul unor idei 
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sarcinilor de lucru. 
profesorului 


Impune puncte de vedere. Ajutá elevii sá inteleagá si sá explice punctele 
de vedere proprii. 


Se consideră şi se manifestă in permanenţă [Este partener în învăţare. 
„ca un părinte". 


Modul de Învăţarea are loc predominant prin memorare |Invätarea are loc predominant prin formare de 
realizare a $1 reproducere de cunostinte, prin apel doar la |competente si deprinderi practice. 
invátárii exemple „clasice", validate. 


Invátarea conduce la competiţie între elevi, |Invätarea se realizează prin cooperare. 
cu scopul de ierarhizare 


Evaluarea Vizează măsurarea şi aprecierea cunoştinţelor |Vizează măsurarea şi aprecierea competenţelor 
(ce ştie elevul). (ce poate să facă elevul cu ceea ce stie). 


Pune accent pe aspectul cantitativ (cât de Pune accent pe elementele de ordin calitativ 

multă informaţie deţine elevul). (valori, atitudini). 

Vizează clasificarea „staticä" a elevilor, Vizează progresul în învăţare pentru fiecare 
elev. 


De fapt, diferenţa dintre didactica tradiţională şi cea actuală constă în modul de concepere şi 
organizare a situaţiilor de învăţare (riguros dirijate în primul caz şi având autonomie de diferite grade, în 
cel de-al doilea). Altfel spus, o strategie este legitimă sau ilegitimă nu în general, ci potrivit unor 
circumstanţe concrete; profesorul eficient este acela care ştie: 

o Sáselectioneze 

o Sà combine 

o sa varieze diferite metode 

o sa aleagă strategii adecvate. 


III. Proiectarea demersului didactic 


Predarea reprezintă activitatea profesorului de organizare şi conducere a ofertelor de învăţare care are 
drept scop facilitarea şi stimularea învăţării eficiente la elevi. 

Proiectarea demersului didactic este acea activitate desfăşurată de profesor care constă în anticiparea 
etapelor şi a acţiunilor concrete de realizare a predării. Proiectarea demersului didactic presupune: 

- lectura personalizată a programelor şcolare; 

- planificarea calendaristică; 

- proiectarea secventialá (a unităţilor de învăţare). 


HI.1. Lectura personalizată a programelor şcolare 
În contextul noului curriculum, conceptul central al proiectării didactice este demersul didactic personalizat, 
iar instrumentul acestuia este unitatea de învăţare. Demersul personalizat exprimă dreptul profesorului - ca 
şi al autorului de manual - de a lua decizii asupra modalitátilor pe care le consideră optime în creşterea 
calităţii procesului de învatamant, respectiv, răspunderea personală pentru a asigura elevilor un parcurs şcolar 
individualizat, în funcţie de condiţii şi cerinţe concrete. 


LECTURAREA PROGRAMEI se realizează “pe orizontală” în succesiunea următoare: 


Competente Competente Continuturi Activitati 
Generale > Specifice > > de invatare 


111.2.Planificarea calendaristică 


In contextul noului curriculum, planificarea calendaristicá este un document administrativ care asociazá 
elemente ale programei cu alocarea de timp considerata optima de cátre profesor pe parcursul unui an scolar. 

In elaborarea planificárilor calendaristice recomandám parcurgerea urmátoarelor etape: 

1. Realizarea asocierilor dintre competentele specifice si continuturi. 

2. Impärtirea in unitäti de invätare. 

3. Stabilirea succesiunii de parcurgere a unitätilor de invätare. 
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4. Alocarea timpului considerat necesar pentru fiecare unitate de invätare, in concordantá cu competentele 
specifice si continuturile vizate. 
Planificárile pot fi intocmite pornind de la urmátoarea rubricatie 


Unitatea scolará..................... 
Disciplina............................. Profesor................................ 
Clasa/Nr. ore pe sápt./ .............. 


Planificare calendaristicá 
Anul scolar.............. 


Unitáti de Competente Continuturi Nr. de ore Sáptámána Observatii 
invátare specifice alocate 


In acest tabel: 

- Unităţile de învăţare se indică prin titluri (teme) stabilite de către profesor. 

* [n rubrica Competente specifice se trec simbolurile competentelor specifice din programa scolarä. 

* Continuturile selectate sunt cele extrase din lista de continuturi ale programei. 

e Numarul de ore alocate se stabileste de catre profesor in funcţie de experienţa acestuia si de nivelul de achiziții 
ale elevilor clasei. 

Íntregul cuprins al planificárii are valoare orientativá, eventualele modificári determinate de aplicarea 
efectivá la clasá putänd fi consemnate in rubrica Observatii. 

O planificare anuală corect întocmită trebuie să acopere integral programa şcolară la nivel de competente 
specifice şi conținuturi. 


111.3. Proiectarea unei unităţi de învăţare 


Elementul generator al planificării calendaristice este unitatea de învăţare. 

O unitate de învăţare reprezintă o structură didactică deschisă şi flexibilă,care are următoarele caracteristici: 
- determină formarea la elevi a unui comportament specific, generat prin integrarea unor competenţe specifice; 
- este unitară din punct de vedere tematic; 

- se desfăşoară în mod sistematic şi continuu pe o perioadă de timp; 

- se finalizează prin evaluare. 

Detaliem în continuare elementele esenţiale ale proiectării unei unităţi de învăţare. 
Se recomandă utilizarea următorului format. 


Unitatea scolará..................... 
Disciplina............................. Profesor................................ 
Clasa/Nr. ore pe sápt./ .............. 


Proiectul unităţii de invàtare......................................... 
Nr. de ore alocate.................... 


Be D ecifice - 


- Continuturi: apar inclusiv detalieri de continut necesare in explicitarea anumitor parcursuri, respectiv in 
cuplarea lor la baza proprie de cunoastere a elevilor. 

« In rubrica Competente specifice se trec simbolurile competenţelor specifice din programa şcolară 

- Activităţile de învăţare pot fi cele din programa şcolară, completate, modificate sau chiar înlocuite de 
altele, pe care profesorul le consideră adecvate pentru atingerea obiectivelor propuse. 

e Rubrica Resurse cuprinde specificări de timp, de loc, forme de organizare a clasei, 
material didactic folosit etc. 

- în rubrica Evaluare se menţionează instrumentele sau modalitatile de evaluare aplicate la clasă. 

Finalul fiecărei unităţi de învăţare presupune Evaluare sumativă. 
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Desi denumirea si alocarea de timp pentru unitátile de invátare se stabilesc la inceputul anului scolar prin 
planificare, este recomandabil ca proiectele unitatilor de invatare sá se completeze ritmic pe parcursul anului, 
avänd in avans un interval de timp optim pentru ca acestea sà reflecte cát mai bine realitatea. 

In completarea rubricatiei, se urmareste corelarea elementelor celor cinci coloane. Practic pe baza indicatiilor 
din planificare se fac detalierile pe orizontalä, ordonänd activitatile in succeesiunea derulärii, raportandu-le la 
competente şi specificând resursele necesare bunei desfăşurări a procesului didactic. 

Proiectarea unităţii de învăţare - ca si a lectiei - începe prin parcurgerea schemei urmatoare: 


În ce scop voi face? —9 Ce voi face? —— Cu ce voi face?——P Cum voi face? ————— — 9 Cat s-a realizat? 


Y Y Y Y 


Identificarea Selectarea Analiza resurselor Determinarea activităţilor de Stabilirea instrumentelor 
competenţelor conţinuturilor învăţare de evaluare 


AME A A AAA 


Conceptul de unitate de invátare are rolul sá materializeze conceptul de demers didactic personalizat, 
flexibilizäd proiectarea didacticá si definind in acest sens pentru practica didacticá premise mai bine 
fundamentate din punct de vedere pedagogic. 

Identificarea unei unitátii de invátare se face prin tema acesteia. Stabilirea temei de catre profesor pe baza 
lecturii programei, utilizänd surse diverse, este primul pas in identificarea unitätilor de invätare in care va fi 
impartitá materia anului scolar, respectiv, in organizarea unu demers didactic personalizat. Temele sunt 
enunturi complexe legate de analiza scopurilor invatárii, formulări fie originale, fie preluate din lista de 
continuturi a programei, sau din manual formuläri care reflectä din partea profesorului o intelegere profundá 
a scopurilor activitatii sale, talent pedagogic, inspiratie, creativitate. 

Activitátile de invátare se consruiesc prin corelarea competentelor cu continuturile si presupun orientarea 
către un anumit scop, redat prin tema activității. In momentul propunerii lor spre rezolvare elevilor, 
activitățile de învăţare vor fi transpuse într-o anumită formă de comunicare inteligibilă nivelului de vârstă. 
Intr-o abordare pragmatică, resursele cuprind acele elemente care asigură cadrul necesar pentru buna 
desfasurare a activitatilor de învăţare. Astfel, profesorul va menționa în această rubrică forme de organizare a 
clasei (tipuri de interacțiuni ale resurselor umane), mijloace de invátamant, alocarea de timp, precum şi orice 
alte elemente pe care le consideră utile în derularea scenariului didactic. 

In condiţiile noului curriculum, lectura programei şi a manualelor nu mai este în mod obligatoriu liniară. 
Programa trebuie parcursă în mod necesar de către toti , dar ea, ca şi manualele se pliază unei citiri personale 
şi adaptate. Asupra conţinuturilor programei profesorul poate interveni prin regruparea lor sub temele 
unităților de învăţare pe care le-a stabilit. 


III.4. Proiectarea activităţii de evaluare se realizează concomitent cu proiectarea demersului de 
predare/invátare şi în deplină concordanță cu acesta. Câteva întrebări utile în proiectarea instrumentelor de 
evaluare sunt urmatoarele: 

+ Care sunt competențele din programa şcolară, pe care trebuie să le dobândească elevii? 

+ Care sunt performanțele minime, medii şi superioare pe care le pot atinge elevii, pentru a demonstra 

că au atins aceste competenţe? 

+ Care este specificu colectivului de elevi pentru care îmi propun evaluarea? 

+ Când şi in ce scop evaluez? 

+ Pentru ce tipuri de evaluare optez? 

- Cu ce instrumente voi realiza evaluarea? 

- Cum voi proceda pentru ca fiecare elev sa fie evaluat prin tipuri de probe cát mai variate astfel încât 

evaluarea să fie cât mai obiectivă? 

- Cum voi folosi datele oferite de instrumentele de evaluare administrate, pentru a elimina eventualele 

blocaje constatate în formarea elevilor şi pentru a asigura progresul scolar al fiecaruia dintre ei? 


PREDICTIVĂ (INIŢIALĂ) 


TIPURI 
DE 
EVALUARE 


FORMATIVĂ (CONTINUĂ) 


SUMATIVĂ (FINALĂ) 
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us e Probe scrise 
TRADITIONALE Probeoralé 


Probe practice 


METODE SI 
INSTRUMENTE 
DE 
EVALUARE 


Observarea sistematicá a elevilor 
Investigatia 

Proiectul 

Portofoliul 

Tema pentru acasá 

Tema de lucru in clasá 
Autoevaluarea 


Adeseori, evaluarea formativă este înlocuită cu evaluarea curentă, în acceptiunea tradițională de “notare 
ritmică”, constând în probe stereotipe precum dictări, calcule, compuneri, diverse tipuri de exerciţii etc., care 
sunt apreciate prin note în mod aproximativ, fără interes în ceea ce priveşte nivelul cognitiv, afectiv, 
psihomotor, relational. O astfel de evaluare are în vedere doar unele tipuri de comportamente, de obicei 
nerelevante pentru personalitatea elevului şi neglijează aspecte importante ca: gândirea, imaginaţia, 
atitudinea de responsabilitate, adoptarea unor metode proprii de lucru, competenţa de comunicare şi de 
relationare etc. 

Ceea ce este generalizat în evaluarea curentă din şcoli este stocarea în memorie a abstractilor şi 
promptitudinea reproducerii acestora. Multe cunoştinţe şi capacități care necesită evaluare sunt ignorate, deşi 
sunt, în egală măsură, variabile importante ale învățării, cum ar fi: atitudinea elevului fata de învăţare, fata de 
disciplina de studiu, fata de educator şi fata de interrelatiile din interiorul colectivului de elevi, modul în care 
elevul învață (sistematic sau sporadic), modul cum abordează cunoştinţele pentru a rezolva probleme 
practice, specifice vieţii cotidiene etc. 

Focalizată pe unitatea de învăţare, evaluarea ar trebui să asigure evidenţierea progresului înregistrat de 
elev în raport cu sine însuşi, pe drumul atingerii competențelor prevăzute în programă. Este important să fie 
evaluată nu numai cantitatea de informaţie de care dispune elevul, ci, mai ales, ceea ce poate el să facă 
utilizând ceea ce ştie sau ceea ce intuieşte. 

In acest sens, câteva aspecte pot fi avute în vedere: 

- modificarea raportului dintre evaluarea sumativă, care inventariază, selectează şi ierarhizează prin notă şi 
evaluarea formativă, ce are drept scop valorificarea potențialului de care dispun elevii şi conduce la 
perfecționarea continuă a stilului şi a metodelor proprii de învăţare; 

- realizarea unui echilibru dinamic între evaluarea scrisă şi evaluarea orală: aceasta din urmă, desi 
presupune un volum mare de timp pentru aprecierea tuturor elevilor şi blocaje datorate emotiei sau timiditätii, 
prezintă avantaje deosebite, ca: realizarea interacțiunii elev-profesor, demonstrarea comportamentului 
comunicativ şi de inter-relationare a elevului. 

- folosirea cu mai mare frecvenţă a metodelor de autoevaluareşi evaluare prin consultare în grupuri mici. 

În raport cu momentele realizării evaluării, în proiectul unităţii de învăţare apar specificaţii: evaluare 
iniţială, formativă sau sumativă. 

Fiecare activitate de evaluare a rezultatelor şcolare trebuie însoțită în mod sistematic de o autoevaluare a 
procesului pe care profesorul l-a desfăşurat cu toti elevii şi cu fiecare elev. Numai astfel pot fi stabilite 
modalităţile prin care poate fi reglată, de la o etapă la alta, activitatea de învăţare / formare a elevilor în mod 
diferențiat. 


111.4.1. Tipuri de itemi 


Item = <întrebare> + <formatul acesteia> + <răspunsul aşteptat> 


Teoria şi practica evaluării evidenţiază mai multe citerii pe baza cărora pot fi clasificați itemii. Unul dintre 
criteriile cel mai des utilizate este acela al gradului de obiectivitate oferit în corectare. In funcție de acest 
criteriu, itemii pot fi clasificați în trei mari categorii: 
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a. Itemii obiectivi asigurá un grad de obiectivitate ridicat in másurarea rezultatelor scolare si testeazä un 
numár mare de elemente de continut intr-un interval de timp relativ scurt. Ráspunsul asteptat este bine 
determinat, ca si modalitatea de notare a acestuia. 


b. Itemii semiobiectivi permit ca ráspunsul asteptat sá nu fie totdeauna unic determinat, modalitatea de 
corectare si notare inducánd uneori mici diferente de la un corector la altul. Acestia testeazá o gamá mai 
variatá de capacitáti intelectuale, oferind in acelasi timp posibilitatea de a utiliza si materiale auxiliare in 
rezolvarea sarcinilor de lucru propuse. 


c. Itemii subiectivi (cu ráspuns deschis) solicitá un ráspuns amplu, permitánd valorificarea capacitátilor 
creative ale elevilor. Acestia sunt relativ usor de construit, principala problemá constituind-o modul de 
elaborare a schemei de notare astfel încât sá se poată obține unitate si uniformitate la nivelul corectării. 


a. Itemi obiectivi 

Fie cá este vorba de activitáti de proiectare si programare (Informaticá), fie cá este vorba de activitáti de 
utilizare si combinare a instrumentelor informatice (Tehnologia Informatiei), lucrul cu calculatorul implicá 
formulári standardizate, lipsite de echivoc, itemii obiectivi si cei semiobiectivi repezentänd instrumente de 
evaluare fracvent aplicate la aceste discipline. 


Itemii obiectivi sunt caracterizati prin: 
structurarea sarcinilor propuse si standardizarea formatului lor de prezentare; 
corelarea strictá a sarcinilor cu obiectivele de evaluärii; 
capacitatea de a testa un numár mare de elemente de continut intr-un timp relativ scurt; 
obiectivitate privind aprecierea räspunsului; 
posibilitatea asocierii cu un sistem de notare extrem de simplu: punctajul aferent se acordá integral, se 
acordá partial conform unei reguli (formule) de calcul sau nu se acordá deloc (in functie de ráspunsul 
asteptat); 
> rolul secundar pe care il au de a obişnui elevul cu formulări standard, ştiinţifice, elemente utile in 
construirea ráspunsurilor pentru itemii semiobiectivi si subiectivi. 


v v v v ON 


a.1. Itemi cu alegere dualá 

Alegerea dualá presupune formularea unei cerinte cu douá variante complementare de ràspuns 

(Adevarat/Fals, Da/Nu, Corect/Incorect etc.). 

Se pot verifica prin intermediul itemilor cu alegere dualá: 

- cunoştinţele legate de corectitudinea sintactică a unor expresii (comenzi, instrucțiuni, notații etc.); 

- înțelegerea semnificației unor noţiuni din terminologia de specialitate (denumiri, instrumente de 
prelucrare, metode de rezolvare, proprietăţi etc.) 

- recunoaşterea unor explicaţii, definiţii, sau imagini. 


Itemii de acest tip se prezintă sub forma unor întrebări sau enunturi, efortul elevului reducându-se la 
identificarea unui răspuns din două posibile. Achizitiile evaluate prin itemii cu alegere duală sunt de regula 
rudimentare. Fac excepţie enunturile care pun în evidenţă justificări ale unor proprietăți, operații sau reguli, 
justificări care necesită achiziţii cognitive superioare. Tot în categoria itemilor cu alegere duală se pot realiza 
cerințe care necesită din partea elevului operaţii de anticipare a efectului unei operaţii prin aplicarea unui 
sistem riguros de cunoştinţe într-un context nou. Aceştia sunt itemii cu cel mai înalt grad de dificultate. 

Atragem atenţia asupra faptului că lipsa “firului roşu“ care pune în evidență elementele sistematice întâlnite 

în utilizarea unui produs soft (chiar şi în cazul unui soft de bază) conduc la un experimentalism accentuat 

care împiedică formarea capacităţii elevului de a se adapta situaţiilor noi, neexersate. 

Factorul de discriminare fiind însă extrem de mic, elevul va putea obţine un rezultat acceptabil la un test format 

numai din astfel de itemi alegând la întâmplare un răspuns dintre cele două admise pentru fiecare item în parte. 

De obicei, itemii cu alegere duală sunt formulati în combinaţie cu itemi subiectivi de tipul “Justificati...”, 

“Scrieţi varianta corectă...”, *Explicati în ce constă eroarea...“ etc. În aceste cazuri, o parte din punctaj este 

alocată justificări. 

Pentru proiectarea corectă a itemilor cu alegere duală este necesară respectarea următoarelor cerinţe: 

> formularea clará a enuntului, fárá ambiguitáti sau formulári incomplete; 

» dacă se solicită aprecierea cu ADEVARAT/FALS, se vor evita enunturile foarte generale; 

» selectarea unor enunturi relevante pentru domeniul de cunoastere sau categoria de competente testata 
(uneori, efortul de a realiza enunturi fara echivoc duce la elaborarea de itemi nesemnificativi din 
punct de vedere educational sau stiintific); 

» se va evita utilizarea unor enunturi negative, acestea conducánd la rationamente ce folosesc dubla 
negatie, inducánd un grad inalt de ambiguitate; 
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» se vor evita enunturile lungi si complexe, prin eliminarea elementelor redundante inutile in raport cu 
ideea enunfului si cerinfa itemului; nu se va folosi un limbaj academic, o terminologie foarte 
specializată sau o construcţie lingvistică stufoasă şi greoaie; 


> se va evita introducerea a doud idei intr-un singur enunf, cu exceptia cazului in care se doreste 
evidentierea relatiei dintre acestea; 

» enunturile vor fi aproximativ egale ca lungime; 

» enunturile adevárate sau false sa fie aproximativ egale ca numär, dar nu exact egale, deoarece acesta 


ar putea constitui un indiciu dupa care elevul incearca sa ghiceascá raspunsul corect. 


a.2. Itemi de tip pereche 

Itemii de tip pereche solicitá stabilirea unor corespondente intre informatiile distribuite pe douá coloane. 
Prima coloaná contine informatii de tip enunt (premise), cea de-a doua coloaná continänd informatii de tip 
räspuns. Elevului i se solicitá sä asocieze fiecare enunt cu un unic ráspuns. 

Cele douá coloane sunt precedate de instructiuni de asociere in care i se explicá elevului tehnica de 
formare a perechilor (să unească printr-o linie, să rescrie perechile asociate sau doar elementele lor de 
identificare etc.) şi se precizează dacă un răspuns poate fi folosit la mai mult de un enunţ (dacă funcția de 
asociere este injectivă sau nu), eventual dacă există răspunsuri care nu vor fi folosite niciodată (dacă funcția de 
asociere este surjectivă sau nu). 

Se verifică prin intermediul itemilor de tip pereche capacitatea elevului de a stabili corelaţii între: 

- funcții şi instrumente; 

- simboluri şi concepte; 

- termeni şi definiţii; 

probleme şi metode de rezolvare. 

Itemii di acest tip permit abordarea unui volum mare de informatie intr-un interval de timp relativ redus. 

Factorul de discriminare este ceva mai mare decát in cazul itemilor cu alegere dualá, strategia de asociere “la 

intämplare” neconducänd decät in situatii foarte rare la un rezultat acceptabil privind rezultatul testului. 

Pentru proiectarea corectá a itemilor de tip de pereche este necesará respectarea urmátoarelor cerinte: 

> utilizarea unui material omogen, dintr-o sferă relativ restrânsă; 

> utilizarea unui număr inegal de premise şi răspunsuri, astfel încât, dacă elevul asociază corect n-1 
enunturi dintre cele n date, să nu rezulte automat răspunsul pentru cel de-al n-lea enunţ; 

> aranjarea listei de răspunsuri (mai ales dacă sunt multe) într-o ordine logică, astfel încât căutarea 
răspunsului în listă să se realizeze cât mai comod; 

> aranjarea enunturilor în listă astfel încât să nu se poată intui o regulă de asociere (referintele să fie 
“încrucişate "); 

> aranjarea coloanelor astfel încât acestea să încapă în întregime pe aceeaşi pagină. 


a.3. Itemi cu alegere multiplă 
Itemii cu alegere multiplă sunt cele mai utilizate tipuri de itemi, în special în testele standardizate 
(bacalaureat, admitere etc.) 
Un item cu alegere multiplă este format dintr-un enunț numit premisă sau bază şi un număr de opțiuni din 
care elevul trebuie să aleagă un singur răspuns numit cheie. Celelalte răspunsuri, neconforme cu cerința, dar 
plauzibile poartă numele de distractori. 

Se verifică prin intermediul itemilor de tip pereche capacitatea elevului de a identifica: 
- definiții şi notații; 
- instrumentul adecvat unei prelucrări; 
- secvenţe de program care realizează o anumită prelucrare; 
-  expresii cu o valoare dată; 
- termeni şi expresii de specialitate; 
- metode de rezolvare şi tehnici de implementare. 
Itemii de acest tip permit abordarea unui volum mare de informatie într-un interval de timp relativ redus, 
oferind posibilitatea evaluării unor achiziţii cognitive complexe, deşi nu pot măsura capacitatea elevului de 
a-şi organiza şi exprima ideile. Sunt forme de testare cu un grad mare de fidelitate, iar factorul de 
discriminare este mai mare decât în cazul celorlalți itemi obiectivi. Abilitatea profesorului de a elabora 
distractori cât mai plauzibili, care să construiască toate alternativele posibile de a greşi, contribuie la reuşita 
aplicării testelor cu alegere multiplă. Erorile comise de elevi oferă profesorului informații suplimentare 
necesare în autoreglarea procesului de învățământ. 
O categorie de itemi cu alegere multiplă solicită răspunsul corect, celelalte variante fiind greşite, în timp ce 
alti itemi solicită cel mai bun răspuns, pe baza unei discriminări complexe. În aceste cazuri trebuie 
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manifestatá grijá la formularea cerintei astfel incát criteriul de discriminare a “celui mai bun räspuns” sà 

reiasá clar din enunt. 

Pentru proiectarea corectá a itemilor cu alegere multiplá este necesará respectarea urmátoarelor cerinte: 

stabilirea clară a cerintei, în concordanţă cu obiectivul de evaluare; 

furnizarea tuturor informaţiilor necesare în premisă, eliminându-se materialul irelevant; 

formularea premisei folosind afirmaţii sau întrebări pozitive; 

construirea unor alternative plauzibile, aflate în concordanţă cu premisa; 

construirea itemului astfel încât sá existe o singură alternativă “corectă” sau “cea mai bună”; 

construirea unor alternative astfel încât distractorii să fie în mod cert “gresiti” sau “mai putin buni”, iar 

varianta cheie să fie în mod cert “corectă” sau "cea mai bună”; 

> aranjarea listei de răspunsuri într-o ordine logică, astfel încât căutarea răspunsului în listă să se 
realizeze cât mai comod; 

> construirea ansamblurilor de itemi cu alegere multiplă astfel încât răspunsurile să ocupe poziţii diferite 
în lista de variante (să nu fie în mod constant al doilea răspuns, de exemplu) 


VV VV V ON 


b. Itemi semiobiectivi 
Itemii semiobiectivi formeazá o categorie de instrumente de evaluare ce solicitá construirea partialá sau 
totalá a unui ráspuns pe baza unei sarcini definite. 


Itemii semiobiectivi sunt caracterizati prin: 

> posibilitatea de a testa o gamă mai largă de capacităţi intelectuale si rezultate ale învățării; 

> crearea unor situaţii cognitive de nivel mai ridicat prin solicitarea de elaborare a răspunsului şi nu de 
alegere a lui dintr-o multime prestabilitá, ca in cazul itemilor obiectivi; 

»  raportarea partial subiectivá a profesorului in raport cu ráspunsul formulat (ráspunsul poate fi scris 
ordonat sau dezordonat, formularea poate fi mai clará sau mai neclará, termenii folositi se pot incadra in 
niste standarde stiintifice sau pot fi variante particulare ale acestora etc.) 

> posibilitatea asocierii unui sistem de notare in care pot să intervină situaţii neprevăzute (răspunsuri 
neasteptate, care comportá raportári noi la barem). 


b.1. Itemi cu ráspuns scurt / de completare 
Itemii cu ráspuns scurt solicitá ca elevul sá formuleze un ráspuns scurt sau sá completeze o 
afirmatie astfel incát aceasta sá capete sens sau sá aibá valoare de adevár. 
Se pot verifica prin intermediul itemilor cu ráspuns scurt si de completare: 
- cunoaşterea unor noţiuni, expresii de specialitate, simboluri, notații etc.; 
- recunoaşterea şi nominalizarea unor elemente vizuale specifice unui anumit mediu de lucru; 
- capacitatea de integrare a unor elemente necesare din punct de vedere sintactic sau semantic într-un 
context dat; 
- schimbarea unor elemente dintr-un context dat astfel încât sá se realizeze o finalitate precizată. 


Itemii cu răspuns scurt se prezintă cel mai des sub forma unor întrebări. Ei solicită un răspuns sub o formă 
restrânsă (un număr, un simbol, un cuvânt, o expresie, o propoziţie sau frază concisă). 
Itemii de completarea se prezintă sub forma unui enunţ, unei afirmaţii incomplete. Ei solicită găsirea 
cuvîntului sau sintagmei care completează şi dă sens enuntului respectiv. 
Pentru proiectarea corectă a itemilor cu răspuns scurt / de completare este necesară respectarea 
următoarelor cerinţe: 


> formularea enuntului astfel încât să admită un răspus scurt, exprimat cu precizie; 

> formularea enuntului astfel încât acesta să admită un singur răspuns corect, pe cât posibil; 

> rezervarea unor spaţii pentru răspuns care sá sugereze numărul de cuvinte aşteptate (dacă acest lucru nu 
reprezintă un indiciu), nu şi dimensiunea lor; 

> vizarea unui răspuns care să reprezinte o sinteză de cunoştinţe sau un rezultat al înţelegerii unei situaţii 
şi mai puţin o reproducere a unor informaţii. 


b.2. Întrebări structurate 
Întrebările structurate solicită, printr-un sistem de subîntrebări relative la o temă comună, răspunsuri de tip 
obiectiv, răspunsuri scurte sau de completare prin care se pot evalua cunoştinţele complexe referitoare la 
tema respectivă fără a solicita elaborarea unui răspuns deschis (eseu). 
Se pot verifica prin intermediul întrebărilor structurate: 
- capacitatea de a urmări, recunoaşte, adapta şi construi un algoritm pe o temă dată sau un program într-un 
limbaj de programare; 
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-  capacitatea de a realiza din aproape in aproape o prelucrare complexä utilizänd un mediu de lucru informatic. 

O intrebare structuratá poate sá continá materiale suport si informatii suplimentare ce se adaugá treptat, 

conferind procesului de evaluare varietate, complexitate si gradualitate. Se pot verifica totodatá cunostinte, 

dar si priceperi si deprinderi sporind gradul de obiectivitate in raport cu itemii cu ráspuns deschis. 

Subintrebárile ce formeazá itemul permit cresterea progresivá a dificultätii cerintelor, dar este recomandat ca 

subintrebárile sä fie independente, adicá räspunsul la o intrebare sá nu depindá de ráspunsul la intrebárile 

precedente. Proiectarea lor necesitá atentie, pricepere si timp. 

Pentru proiectarea corectá a intrebárilor strucutrate este necesará respectarea urmátoarelor cerinte: 

> redactarea subintrebarilor astfel încât acestea să solicite răspunsuri simple la început crescând pe 
parcurs dificultatea acestora; 

> formularea unor subintrebari autocontinute (al căror răspuns corect să nu depindă de răspunsul corect 
la una dintre întrebările precedente;realizarea concordantei dintre enunţul general (tema întrebării) si 
subintrebarile formulate. 


c. Itemi subiectivi (cu răspuns deschis) 


Itemii subiectivi formează o categorie de instrumente de evaluare ce vizează creativitatea elevului, 
originalitatea şi caracterul personal al răspunsului. Deşi sunt uşor de formulat, itemii subiectivi ridică 
probleme privind obiectivitatea evaluării. 

Itemii subiectivi sunt caracterizați prin: 

> abordare globală a unei sarcini asociate unui obiectiv ce nu poate fi evaluat prin intermediul itemilor obiectivi; 

> crearea unor situaţii cognitive de nivel foarte ridicat prin solicitarea de a realiza interacțiuni reale si 
complexe între cunoştinţe, abilități şi deprinderi; 

> raportarea subiectivă a profesorului în raport cu răspunsul formulat; 

> necesitatea predefinirii unor criterii privind baremul de corectare şi notare, criterii clare, judicioase şi 
puternic anticipative; 

> posibilitatea, în cazul în care baremul nu a prevăzut toate situaţiile de interpretare şi construire a 
răspunsului, a unor elemente noi (răspunsuri neaşteptate) care comportă reanalizarea baremului. 

În cazul informaticii şi tehnologiei informaţiei se pot elabora itemi subiectivi de tip eseu (structurat sau liber) 

şi itemi de tip problemă (care necesită proiectare, redactare şi uneori implementare a rezolvării). 


c.1. Itemi de tip eseu 

Itemii de tip eseu pot fi structurati sau liberi. Itemii structurati sunt construiti astfel incát ráspunsul asteptat sá 
fie “orientat” cu ajutorul unor elemente din enunţ (indicii privind ordinea de tratare, numărul de linii, 
formularea răspunsului, ideile care trebuie să fie atinse etc.). Un eseu liber nu furnizează în enunţ nici un fel 
de indicaţii sau constrângeri, elevul având libertatea să-şi strucutreze cum consideră şi cum poate materialul 
pe care-l solicită enunţul. Acest tip de eseu comportă operaţii de maximă complexitate (analiză, sinteză, 
sistematizare şi restructurare) lăsând frâu liber fanteziei şi capacităţilor creative ale elevului. 

Deoarece la informatică elementele de creativitate se manifestă mai ales prin rezolvări de probleme şi 

proiecte, iar în cazul tehnologiei informaţiei prin teme practice şi proiecte, itemii de tip eseu preferaţi sunt cei 

structurati, un eseu liber nefiind necesar decât rar, pentru anumite teme cu un volum mai mare de elemente 

“informative” în raport cu achizițiile “operaționale”. 

Se pot verifica prin intermediul itemilor de tip eseu: 

- cunoştinţele globale legate de stuctura sistemelor de calcul, sisteme de operare, evoluţia istorică a 
sitemelor hard şi soft, principiile de utilizare a unei anumite aplicaţii, etapele conceptuale ale proiectării 
unei aplicaţii etc. 

- capacitățile de sistematizare a unor elemente prin construirea unor scheme sau reprezentări grafice. 

Itemii de tip eseu se prezintă sub forma unor cerințe generale însoţite eventual (pentru eseurile structurate) 

de indicii privind tratarea cerinfei. Se pot adăuga restricţii privind întinderea in timp sau spaţiu (număr 

rânduri, pagini, paragrafe etc.) sau privind forma de prezentare a răspunsului. 


c.2. Itemi de tip problemă 


Rezolvarea unei probleme presupune soluționarea unei situații conflictuale generată de neconcordante ivite 
între sistemul de achiziţii şi situaţiile concrete descrise de un enunț. Aceste neconcordante sunt generate 
uneori de nepotrivirea între contextul general al cunoştinţelor şi situaţiile particulare în care acestea trebuie 
să fie aplicate. Alteori achiziţiile sunt dobândite prin experimente (situaţii particulare) şi, pentru a fi aplicate 
în cu totul alte situaţii, acestea trebuie să fie ridicate la un înalt nivel de abstractizare şi generalizare. 
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Rezolvarea de probleme este o activitate specificá si des utilizatá la disciplina “Informaticä”, 
elementele gändirii algoritmice, metodele de rezolvare si tehnicile de implementare fiind supuse unui “tir” 
sistematic de probleme prin care acestea sá formeze competente reale de programare. 

Capacitätile cognitive superioare legate de aplicare creativá, gándire divergentá, descoperirea conditiilor 
interne, alegerea modelului adecvat etc. sunt verificate prin itemi de acest tip. Obiectivele urmärite prin 
utilizarea rezolvárii de probleme sunt: 

- obtinerea informatiilor necesare rezolvárii problemei; 

-formularea si testarea ipotezelor; 

-descrierea metodei de rezolvare a problemei; 

-elaborarea unui raport despre rezultatele obtinute; 

-posibilitatea de generalizare si transfer a tehnicilor 

de rezolvare. 
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Cerinţe suplimentare asociate unei probleme pot pune în evidenţă capacitatea elevului de a estima eficienţa unei 
rezolvări, de a construi un algoritm conform unor criterii (limita de memorie, număr de instrucțiuni etc.). 


Se pot formula probleme în care se furnizează algoritmul şi se cere un enunț de problemă care se rezolvă prin 
intermediul algoritmului respectiv. Acest tip de item impune o analiză atentă a algoritmului şi asocierea lui 
cu una dintre problemele sau prelucrările numerice întâlnite la matematică, fizică sau în alte domenii, o 
formulare a enuntului care să se caracterizeze prin coerență. 


Enunturile pot fi formulate abstract, “la obiect” sau pot crea un “context” care trebuie modelat pentru a 
se ajunge la rezolvarea propriu-zisă. “Povestea” în spatele căreia se ascunde problema are de cele mai multe 
ori conotaţii practice, descriind situaţii concrete de prelucrare, amintind că rolul programatorului este acela 
de a “ordona” initial informaţia şi operațiile specifice unui anumit context şi abia după aceea de a elabora 
algoritmul, de a implementa şi verifica programul corespunzător. 


Aspecte de aceeaşi natură se întâlnesc şi în domeniul utilizării calculatorului, la Tehnologia 
informaţiei, când beneficiarul formulează un enunţ şi utilizatorul trebuie să-şi aleagă programul de aplicație 
adecvat, din cadrul programului să-şi aleagă obiectele şi instrumentele potrivite, să proiecteze, pe paşi, 
prelucrarea astfel încât “produsul” (documentul, prezentarea, raportul etc.) să răspundă cerințelor şi să fie 
realizat în timp record. Aspectele reale de concepție, de creativitate şi gândire divergentă intervin la 
realizarea machetelor, a prezentărilor etc. 


Evaluarea prin rezolvare de probleme la informatică ridică uneori probleme din punctul de vedere al 

întocmirii baremului de corectare. Unele tendinţe exagerate tind să impună o corectare pe principiul: 

problemă=program funcțional corect (pornind de la premisa că “un program care aproape merge e ca un 
avion care aproape zboară”). Se recomandă totuşi ca baremul de corectare să cuprindă fracțiuni din punctaj 
pentru diferitele aspecte pe care le comportă rezolvarea unei probleme la informatică: corectitudinea 
sintactică, structurarea datelor şi declararea variabilelor, structurarea programului, corectitudinea 
algoritmului, eficienţa algoritmului, tratarea unor situaţii limită, eventual explicarea metodei aplicate (chiar 
daca a fost aplicată greşit) etc. 

Se pot verifica prin intermediul itemilor de rezolvare de probleme: 

- concepția unor algoritmi de rezolvare a problemelor elementare; 

- asimilarea unui algoritm general prin adaptarea lui astfel încât să rezolve o problemă particulară; 

- capacitatea de a alege structurile de program şi de date adecvate rezolvării unei probleme; 

- abilitatea de a implementa programul, de a-l depana, de a-l testa şi, în funcţie de erorile apărute, de a 
reconsidera elementele de sintaxă ale programului, strategiile de structurare a datelor sau însuşi 
algoritmul de rezolvare (în partea practică a probei); 

- capacitatea de a organiza volume mari de date cu ajutorul bazelor de date; 

- discernámántul în a alege un algoritm mai eficient (conform unuia dintre din criteriile studiate: număr 
operaţii, spaţiu de memorie utilizat) 


111.4.2. Metode complementare de evaluare 


Metodele complementare de evaluare reprezintă instrumente suplimentare, nestandardizate, de evaluare 
dispunând de forme specifice cum ar fi: investigația, referatul, portofoliul, proiectul, observarea 
sistematică a activităţii elevului şi autoevaluarea. 
Metodele complementare realizează actul evaluării în strînsă legătură cu procesul educativ, prin 
întrepătrundere cu etapele acestuia, urmărind în special capacitățile cognitive superioare, motivațiile si 
atitudinea elevului în demersul educaţional. 
Metodele alternative de evaluare se caracterizează prin următoarele: 
> capacitatea de a transforma relația profesor-elev inducänd un climat de colaborare şi parteneriat; 
> posibilitatea transformării procesului de evaluare prin înlocuirea tendinței de a corecta şi sancţiona prin 
aceea de a soluţiona erorile semnalate; 

> posibilitatea de a deprinde elevul cu mecanismele de aurocorectare şi autoeducare necesare şi în procesul 
de integrare socială; 

> utilizarea mai amplă a tehnicilor şi mijloacelor didactice; 

> caracterul sumativ, realizat prin evaluarea cunoştinţelor, capacităților şi atitudinilor pe o periadă mai 
lungă de timp şi dintr-o arie mai largă; 

> caracterul formativ, realizat prin valorificarea atitudinii elevului în raport cu propria sa evaluare; 

> capacitatea de a realiza o evaluare individualizată (observare sistematică); 

> capacitatea de a educa spiritul de echipă prin activităţi de grup (investigaţii, proiecte); 
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> caracterul profund integrator realizat prin interdisciplinaritate, educare si instruire mutilateralä. 
1.Investigatia 


Investigatia este o metodá de evaluare si invátare utilizatä foarte des la disciplina Tehnologie informatiei si 
numai ocazional la disciplina Informaticä. 
Organizarea unei activitäti de evaluare si invátare prin metoda investigatiei presupune: 
-  valorificarea metodei de învăţare prin descoperire; 


- studiul unor documentatii complementare, experimentarea unor instrumente de prelucrare 
nestandard, compararea şi generalizarea unor tehnici şi metode utilizate în tehnologie prin cercetarea 
altor izvoare sau prin utilizarea altor instrumente echivalente; 

- extrapolarea cunoştinţelor dobândite şi verificarea ipotezelor formulate; 

- solicitarea unor cunoştinţe sau deprinderi dobândite la alte dicipline prin adaptarea creatoare a 
acestora la cerinţele temei de investigaţie. 

În cele mai multe dintre cazuri investigația trebuie să fie organizată ca muncă independentă depusă de elev, 
dirijată şi sprijinită de profesor. Tehnologia informaţiei, cu multitudinea de aplicaţii software din domenii 
aplicații (de exemplu, aplicaţia românească de tip agendă MyCount difuzată pe Internet): citeşte explicațiile 
asociate butoanelor, opţiunile din meniuri, informaţiile din Help, experimentează operaţiile propuse de 
aplicație imaginând utilitatea practică a acestora şi formulează concluzii generale referitoare la acel soft 
(utilitate, spaţiul ocupat pe disc sau în memorie, spaţiul ocupat de produsele construite cu ajutorul lui, 
calitatea grafică şi funcțională a interfeţei). Investigaţii mai rafinate pot realiza elevii iniţiaţi în programare şi 
în sisteme de operare care disting mult mai multe aspecte “în spatele“ produsului soft investigat (eficienţă, 
posibilitate de dezvoltare, configurare, conflicte cu alte programe etc.). 

Pentru organizarea activităților de investigaţie, profesorul va urmări: 

> formularea generală a temei; 

asigurarea surselor bibliografice sau tehnice necesare; 

formularea unor indicaţii care să directioneze activitatea elevilor; 

urmărirea activităţii elevului în sensul utilizării eficiente şi creatoare a materialului de investigat; 
sprijinirea elevilor sau grupurilor de elevi care întâmpină dificultăți în înțelegerea temei sau a metodelor 
specifice de studiu; 

> încurajarea şi evidenţierea activităţilor creatoare desfăşurate de elevi, a descoperirilor neaşteptate. 


v v v v 


2. Referatul si proiectul 


Referatul reprezintá o formä de imbinare a studiului individual cu activitate de prezentare si argumentare. 
Tema referatului, insotitá de bibliografie si alte surse de documentare (Internet, vizite etc.), este tratatá in 
mod independent de cátre elev si sustinutá apoi in fata colegilor sau altui auditoriu mai larg. Varietatea 
universului informatic (a limbajelor si tehnicilor de programare, a aplicatiilor din domeniul TIC, a noutátilor 
hardware etc.) justificä utilizarea acestei forme de studiu si evaluare la clasá, atät la Tehnologia informatiei 
cát si la Informaticá. Dacá studiul aferent si rezultatul studiului prezintá interes si din punct de vedre practic, 
rezultatul fiind un program (o aplicatie) sau un produs TI complex (rezultatul aplicärii creatoare a 
instrumentelor informatice), dacá bibliografia propusá este mai bogatá si etapele de proiectare (conceptie), 
implementare si testare necesitá un timp mai indelungat, lucrarea poartá numele de proiect. 

Organizarea unei activitáti de evaluare si invátare prin intermediul referatelor si proiectelor presupune: 

-  valorificarea metodei de invátare prin descoperire; 

- studiul unor materiale suplimentare si izvoare de informare diverse în scopul imbogatirii $i activizării 
cunoştinţelor din domeniul studiat sau domenii conexe, prin completări de conţinut ale programei sau 
prin aducerea în atenție a unei problematici complet noi; 

- structurarea informaţiei corespunzătoare unui referat într-un material ce poate fi scris, ilustrat sau 
prezentat pe calculator, activitățile de concepere, organizare, experimentare, reproiectare (dacă este 
cazul), dezvoltare şi elaborare a documentaţiei aferente necesită planificarea unor etape de elaborare şi 
o strategie de lucru, în cazul proiectului; 

- prezentarea referatului sau proiectului de către elevul sau elevii care l-au elaborat, acesta (sau un 
reprezentant al grupului) trebuind să-l susțină, să fie capabil să dea explicații suplimentare, să 
răspundă la întrebări etc. 

Referatul este de regulă o lucrarea de mai mică amploare, dar mai structurată şi mai bogată în 
informaţii decât o temă de muncă independentă aferentă lectiei curente. Proiectul este o lucrare mai amplă a 
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cárei temá este comunicatá sau aleasá din timp, elaborarea unui proiect putánd sá dureze de la 1-2 sáptámini 

pänä la 2-3 luni sau chiar un semestru. Proiectul poate fi elaborat in grup, cu o distribuire judicioasä a 

sarcinilor intre membrii grupului. 

Referatul poate fi utilizat la Informaticä si in egalä mäsurä la Tehnologia informatiei temele referatelor 

vizánd cel mai des domenii de actualitate in productia sofware sau in domeniul TIC. 

Pentru a realiza o evaluare pe bazá de referate, profesorul: 

» va formula teme clare, de complexitate medie, precizind pe cát posibil amploarea lucrárii (cáte pagini, 
durata maximă necesară prezentării etc.) 

> va recomanda sau asigura sursele bibliografice si de informare necesare; 

> îşi va rezerva suficient timp (în perioada de evaluare sau la sfârşitul unor unităţi de învăţare) pentru ca 
elevii însărcinaţi cu elaborarea referatelor să-şi poată prezenta referatul; 

> va supraveghea discuţiile purtate cu elevii asupra conținutului referatului. 


Pentru a realiza o evaluare pe bază de proiecte, profesorul: 


> va formula teme practice, de complexitate sporită, lăsând celor care elaborează proiectul multă libertate 
în a improviza, adapta şi interpreta cerința într-un mod personal; 

> va stabili un termen final şi, în funcţie de modul de evaluare, termene intermediare de raportare; 

va recomanda sau asigura sursele bibliografice şi de informare necesare; 

> îşi va rezerva suficient timp (în perioada de evaluare sau la sfîrşitul unor unităţi de învăţare) pentru ca 
elevii însărcinaţi cu elaborarea proiectelor să-şi poată prezenta rezultatul proiectării; 

> va supraveghea discuţiile purtate cu elevii asupra proiectului. 
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3. Portofoliul 

Portofoliul reprezintá o metodá complexá de evaluare in care un rezultat al evaluárii este elaborat pe baza 
aplicárii unui ansamblu variat de probe si instrumente de evaluare. 

Prin multitudinea de forme şi momente în care se desfăşoară testarea elevului, rezultatul final “converge” 
către valoarea reală a acestuia, sesizând elementele de progres sau regres, ilustrând preocuparea pentru 
lámurirea neclaritátilor, oferind o imagine de ansamblu asupra nivelului cunoştinţelor, gradului de formare a 
abilităților şi gradului de raportare atitudinalá pe care acesta o are față de tema evaluată. Portofoliul este 
realizat pe o periadă mai îndelungată, de la un semestru, un an, până la un ciclu de învăţământ. 

Conţinutul unui portofoliu este reprezentat de rezultatele la: lucrări scrise sau practice, teme pentru 
acasă, investigaţii, referate şi proiecte, observarea sistematică la clasă, autoevaluarea elevului, chestionare de 
atitudini etc. La Tehnologia informației portofoliul se poate constitui dintr-o colecție de lucrări practice 
realizate pe calculator, fiecare vizând anumite aspecte de utilizare. 

Alegerea elementelor ce formează portofoliul este realizată de către profesor (astfel încât acestea să ofere 

informaţii concludente privind pregătirea, evoluția, atitudinea elevului) sau chiar de către elev (pe 

considerente de performanţă, preferinţe etc.) 

Structurarea evaluării sub forma de portofoliu se dovedeşte deosebit de utilă, atât pentru profesor, cât şi 

pentru elev sau părinţii acestuia. 

Pentru a realiza o evaluare pe bază de potofoliu, profesorul: 

> va comunica elevilor intenţia de a realiza un portofoliu, adaptând instrumentele de evaluare ce constituie 
“centrul de greutate” ale portofoliului la specificul disciplinei; 

> va alege componentele ce formează portofoliul, dând şi elevului posibilitatea de a adăuga piese pe care le 
consideră relevante pentru activitatea sa; 

> va evalua separat fiecare piesă a portofoliului în momentul realizării ei, dar va asigura si un sistem de 

criterii pe baza cărora să realizeze evaluarea globală şi finală a portofoliului; 

va pune în evidenţă evoluţia elevului, particularitátile de exprimare şi de raportare a acestuia la aria vizată; 

> va integra rezultatul evaluării portofoliului în sistemul general de notare. 
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4. Observarea sistematicá a activitátii si comportamentului elevilor 


Fisa de observare a activitätii si comportamentului elevului inregistreazä informatii legate de 
particularitätile personalitätii elevului manifestate in procesul didactic, de achizitiile evaluate spontan 
(ráspunsuri sporadice, atitudini semnificative etc.), de progresul inregistrat de acesta. Profesorul construieste 
aceastá fisá in vederea individualizárii procesului sumativ de evaluare, dar sia celui de invátare. 

Pe baza fisei de evaluare se poate realiza si orientarea scolarä si profesionalá a elevului. Informatiile din fisa 
personală au caracter partial secret, parte dintre ele fiind comunicate elevului şi părinţilor acestuia. 
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Un model orientativ de fisä de observare contine: 

> Date generale despre elev (nume, prenume, värstä, climat educativ, conditii materiale, particularitáti 
socio-comportamentale); 

> Particularități ale proceselor intelectuale (gîndire, limbaj, imaginație, memorie, atenție, spirit de 

observaţie etc.); 

Aptitudini şi interese manifestate; 

Particularităţi afectiv-motivationale; 

Trăsături de temperament; 

Atitudini si relationare (cu sine insusi, cu materia studiatá, cu colegii) 

Consideratii privind evolutia aptitudinilor, atitudinilor, intereselor si nivelului de integrare. 

Prin stabilirea copmpetentelor generale ale disciplinei şi achiziţiile cognitive şi comportamentale vizate 
de aceasta, fişa de observare poate să conțină şi considerente legate de atingerea şi formarea competenţelor 
specifice. Completarea fişei se realizează în timp într-un ritm adecvat specificului activităţilor de la disciplina, 
din anul şi de la clasa respectivă, dar şi în funcție de implicarea şi de ritmul individual al elevului. 


v v VV ON 


IV.. Proiectul unitátii de invätare - Proiectul de lectie ? 


Fatá de proiectarea traditionalá centratá pe lectie (ora de curs) - proiectarea unitátii de invátare are urmatoarele 
avantaje: 


e creează un mediu de învățare coerent in care aşteptările elevilor devin clare pe termen 

mediu şi lung; 

e implică elevii în „proiecte de învatare personale" pe termen mediu si lung - rezolvare de 

probleme complexe, luare de decizii complexe, cu accent pe explorare şi reflecţie; 

e implică profesorul într-un „proiect didactic” pe termen mediu şi lung, cu accent pe 

ritmurile de învăţare proprii ale elevilor; 

* dá perspectiva lecţiilor, conferind acestora o structură specifică, în funcție de secvența 

unităţii de învăţare în care se află. 

Proiectul de lecţie - conceput ca document separat - este recunoscut ca o formalitate consumatoare de timp 
şi energie. Proiectul unei unităţi de învăţare conţine suficiente elemente pentru a oferi o imagine asupra fiecărei 
ore. Ca urmare, în tabelul care sintetizeaza proiectarea unitatii de învăţare se pot delimita prin linii orizontale 
(punctate) spatiile corespunzatoare unei ore de curs. Astfel, pentru fiecare lecţie, proiectul unității de învăţare 
oferă date referitoare la elementele de conţinut şi competențele vizate, la care se raportează anumite activităţi 
de învăţare; totodată, sunt indicate resurse materiale, forme de organizare a clasei etc., pentru fiecare activitate 
precum şi instrumente de evaluare necesare la nivelul lectiei (orei). In consecință, dacă proiectul unității de 
învăţare este bine construit, nu mai este necesară detalierea la nivelul proiectului de lecție. 

Lecţia este înţeleasă ca o componentă operațională (Cum?) pe termen scurt a unităţii de învăţare. Dacă 
unitatea de învăţare oferă întelegerea procesului din perspectivă strategică, lecţia oferă înţelegerea procesului 
din perspectiva operativă, tactică. Proiectul unităţii de învăţare trebuie să ofere o derivare simplă a lecţiilor 
componente. Ca urmare, trecerea de la unitatea de învăţare - o entitate supraordonată - la o lecţie componentă 
trebuie să permită o ,replicare" în acelaşi timp functională (De ce?), structurală (Cu ce?) şi operaţională 
(Cum?) a unitatii de învăţare, la o scară temporală mai mică şi într-un mod subordonat. 

Acest mod de tratare orientată către scopuri precise caracterizează organizarea atât a unităţii de învăţare cât şi a 
lectiei. 
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Introducere in Programarea .Net Framework 


Návodari, 20-30 august 2007 


www.microsoft.com/romania/educatie 
http://msdn2.microsoft.com/en-us/express/default.aspx 


